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PREFACE 


The MPC823 User’s Manual discusses the operation, possible configurations, and 
specifications of the MPC823 microprocessor. This manual mainly addresses Revision A of 
the silicon, but exceptions are noted where appropriate. All the sections of the manual are 
organized consistently to make it easier for you to use the manual as a reference. Due to its 
length, the communication processor module section contains special tabs, links, and page 
number references that you can use to get to a specific module. 


Our website (www.mot.com/mpc823) contains a PDF (3.0) version of the manual that 
contains hypertext linked cross-references and index markers, which make it easy for you 
to get in, get the information you need, and get out. However, the links are only operable if 
you download the file of the entire manual (mpc823.pdf). In the future, we plan to have an 
online version of this manual in HTML format. 


STYLES USED IN THIS MANUAL 


Styles make it easier for you to look up the information you need, when you need it. The 
following components are stylized in this manual: 


e Registers are defined in the module to which they belong. If they are mentioned 
elsewhere, they are referred to by their acronym. It is important to note that register 
tables include symbols to denote don’t care, unaffected, and reserved bits. 


1 # indicates that a bit is unaffected 

1 — denotes an undefined quality of a bit 
[() x indicates that a bit is a “don’t care” bit 
‘4 Oor— indicates that a bit is reserved 


¢ Commands appear in BOLD UPPERCASE format. 
e Signals, pins, and bit names appear in UPPERCASE format. 
e Instructions appear in bold lowercase format. 


COMPLEMENTARY DOCUMENTATION 


Throughout this manual, there are references to the following documents that would enable 
you to better understand the MPC823 microprocessor. We recommend that you use these 
manuals in conjunction with the MPC8&23 User's Manual. 


¢ PowerPC™ Microprocessor Family: The Programming Environments for 32-Bit 
Microprocessors (available from your local Motorola sales office using part number 
MPCFPE32B/AD as a reference) 


e USB Specification (available from www.usb.org) 
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ELECTRICAL SPECIFICATIONS 


The most up-to-date electrical specifications for the MPC823 is located on our website. 


CUSTOMER FEEDBACK 


Motorola welcomes any feedback from our customers. To continuously improve our 
documentation, we need to know what our customers need and want. So visit our website 
and tell us! 
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The MPC823 microprocessor is a versatile, one-chip integrated microprocessor and 
peripheral combination that can be used in a variety of portable electronic products. It is a 
low-cost version of the MPC821 microprocessor, except it has been enhanced with 
additional communication and display capabilities. Specifically, it supports the universal 
serial bus and video display systems and the existing LCD interface on the MPC821 device. 
The MPC823 microprocessor particularly excels in low-power, portable, image capture, and 
personal communication products. It integrates a high-performance embedded PowerPC™ 
core with a communication processor module that uses a specialized RISC processor for 
imaging and communication. The communication processor module can perform embedded 
signal processing functions for image compression and decompression and supports six 
serial channels—one serial communication controller, two serial management controllers, 
one I@C port, one universal serial bus channel, and one serial peripheral interface. This 
two-processor architecture consumes power more efficiently than traditional architectures 
because the communication processor module frees the core from peripheral 
responsibilities like imaging and communication. 


1.1 FEATURES 


The following list summarizes the main features of the MPC823: 





e Embedded PowerPC Core Provides 66MIPS (Using Dhrystone 2.1) or 
115K Dhrystones 2.1 at 50MHz 


L1 Single-Issue, 32-Bit Version of the PowerPC Core (Fully Compatible with the 
PowerPC Architecture Definition) with 32 x 32-Bit Fixed-Point Registers 

L} Low Power Consumption, 2.2V Internal, 3.3V I/O Boundary with Microprocessor 
Core, Caches, Memory Management, and I/O in Operation 

1) Performs Branch Folding, Branch Prediction with Conditional Prefetch, without 
Conditional Execution | 

(1 1K Data Cache and 2K Instruction Cache 

[1 Instruction and Data Caches are Two-Way, Set-Associative, Physical Address, 
4-Word Line Burst, LRU Replacement Algorithm, Lockable Online Granularity 

(1 Memory Management Units with 8-Entry Translation Lookaside Buffers (TLBs) and 
Fully Associative Instruction and Data TLBs 

[1 Memory Management Units Support Multiple Page Sizes of 4K, 16K, 512K and 8M 
(1K Protection Granularity at the 4K wade Size); 16 Virtual Address Spaces and 
16 Protection Groups | 
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e Advanced On-Chip Emulation Debug Mode 
¢ Data Bus Dynamic Bus Sizing for 8-,16-, and 32-Bit Buses 


L) Supports Traditional 68K Big-Endian, Traditional x86 Little-Endian, and PowerPC 
Little-Endian Memory Systems 
L) Twenty-Six External Address Lines 
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Completely Static Design (0-50MHz Operation) 
¢ Communication Processor Module 


(1 Interfaces to PowerPC Core Through On-Chip Dual-Access RAM and ne 
- (Serial) DMA Channels on a Dedicated DMA Accelerator 
Q Programmable Memory-to- -Memory and Memory-to-I/O (Including Flyby) DMA — 
Provided by Virtual DMA Support 
~O 5SOMIPS @ 15MHz 
-Q Protocols Supported by ROM or Download Microcode and the Single Hardware 
Serial Communication Controller Include, But Are Not Limited To, the Digital _ 
Portions of: 
— Ethernet/IEEE 802. 3 (CS/CDMA) 
— HDLC/SDLC and HDLC Bus 
— Appletalk 
— Universal Asynchronous Receiver Transmitter (UART) 
— Synchronous UART (USART) 
— Totally Transparent Mode With/Without CRC 
— Asynchronous HDLC 
— IrDA Version 1.1 Serial Infrared 
— Basic Rate ISDN (BRI) in Conjunction with Serial Management 
Controller Channels 
— Primary Rate ISDN 





Li 16 x 16-Bit Multiply Accumulate (MAC) Hardware 
_ — One Operation Per Clock 
— Two Clock Latency and One Clock Blockage 
— Operates Concurrently with Other Instructions 
— Uses DMA Controller to Burst Data Directly into neuister File without Interacting 
with the PowerPC Core 


[3 DSP Functions Are Supported by ROM or Download Microcode and the 
Communication Processor Module DSP Capabilities, Include, But Are 
Not Limited To: | 
— V.32bis Datapump Filters 
— V.34bis Datapump Filters 
— JPEG pain ieee Ice Ceom pies" 


8K Dual-Port RAM. Revision 0 Contains 5K Dual-Port RAM. | 
Twelve Serial DMA (SDMA) Channels 
32-Bit, Harvard Architecture, Scalar RISC Microcontroller 


ooo. 
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[1 Communication-Specific Commands 
1) Supports Continuous Mode Transmission and Reception on All Serial Channels 
LI} Each Serial Channel has Externally Accessible Pins 


e Four Baud Rate Generators. If you are using Mask Revision Base #F 98S, there are only 
two baud rate generators. 


L) Independent and Can Be Connected to A Serial Communication Controller or Serial 
Management Controller 

[1 Allows Changes During Operation 

CL} Autobaud Support Option 


One Serial Communication Controller 


Ethernet/IEEE 802.3 Support (10Mbps and Full-Duplex Operation) 

GeoPort Support 

HDLC Bus Implements an HDLC-Based Local Area Network 

Universal Asynchronous Receiver Transmitter 

Synchronous UART 

Serial Infrared (IrDA) Supporting a Maximum of 4Mbps 

Totally Transparent. Frame Based with Optional Cyclical Redundancy Check 
Maximum Serial Data Rate of 22Mbps 


DUOovoevueo 


¢ One Dedicated High-Speed Serial Channel for the Universal Serial Bus (USB) 
[1 Supports USB Slave Mode At a Maximum of 12Mbps With Four USB Endpoints 


e Two Serial Management Controllers with Externally Accessible Pins 
Ly UART | 
1 Transparent 
General Circuit Interface (GCI) Controller 
[1 Can Be Connected to the Time-Division Multiplexed (TDM) Channels 


e One Serial Peripheral Interface 


_1 Supports Master and Slave Modes 
[1 Supports Multimaster Operation on the Same Bus 


° One I?C® Port 
[1 Supports Master and Slave Modes 
1 Supports Multimaster Environments 
[1 Supports High-Speed Operation 
1 Supports 7-Bit Addressing 
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~ Introduction 


Serial Interface with the Time-Slot Assigner . 
[3 Allows Serial Communication Controller and Serial Management Controllers To Be 
Used in Multiplexed and/or Nonmultiplexed Operation 


Supports T1, CEPT, PCM Highway, DN Basic Rate, ISDN Primary Rate, 
User-Defined 


1- or 8-Bit Resolution 
Allows Independent Transmit and Receive Routing, Frame Syncs, and Clocking 
Allows Dynamic Changes 

Can Be Internally Connected to Three Serial Channels 


General-Purpose Timers 

Li Four 16-Bit Timers or Two 32-Bit Timers. If you are using Mask Revision Base 
#F 98S, there are only two timers. | 

L} Gate Mode Can Enable/Disable Counting 


ra. ft AK. 


Li interrupt Can Be Masked on Reference Match and Event Capiure 


Interrupts 


Seven External Interrupt Request (IRQ) Lines 
One Nonmaskable Interrupt 

Twelve Port Pins with Interrupt Capability 
Ten Internal Interrupt Sources 
Programmable Mlghee Priority neduest 


| Memory Controller (Eight Banks) 


Can be Programmed to Support Almost any Memory Interface 

Each Bank Can Be a Chip-Select or RAS to Support a DRAM Bank 

A Maximum of 30 Wait States per Memory Bank Can Be Programmed 
Glueless Interface to DRAM Single In-Line Memory Modules, Static RAM, 
Electrically Programmable Read-Only Memory, Flash EPROM. | | 
Four CAS lines, Four WE lines, and One OE Line 

Boot Chip-Select Available at Reset (Options for 8-, 16-, or 32-Bit Memory) 
Variable Block Sizes—32K to 256M 

Selectable Write Protection 

On-Chip Bus Arbitration Supports External Bus Master 

Special Features for Burst Mode Support 


Oueoeoeou Oooo 


System Integration Unit 


Hardware Bus Monitor 
Spurious Interrupt Monitor 
Software Watchdog Timer 
Periodic Interrupt Timer 
Low-Power Stop Mode 
Clock Synthesizer 


DOeoeeo 
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_} PowerPC Decrementer 
_} PowerPC Timebase 
L} Real-Time Clock 
4 Reset Controller S 
O) IEEE 1149.1 Test Access Port (JTAG) =) 
©. 
e Video/LCD Controller E 


Video Controller 


— Supports Digital NTSC/PAL Video Encoders and Digital TFT 

— Sequential RGB, 4:4:4, and 4:2:2 YC;C» (CCIR 601) Digital Component 
Video Formats 

— CCIR-656 Compatible 8-Bit Interface Port. 

— Horizontal Sync, Vertical Sync, Field and Blanking Timing Generation with 
Half-Clock Resolution and Programmable Polarity 

— Supports Interlace/Noninterlace Scanning Methods 

— Programmable Display Active Area 

— Programmable Background Color for Inactive Area 

— Glueless Interface for Most Digital Video Encoders 

— Hardware Horizontal Scrolling 

— Uses Burst Read DMA Cycles for Maximum Bus Performance 

— Panel Voltage Control Adjustments for Contrast Set with On- -Chip Timers 

— End-of-Frame Interrupt Generation 


L 


ag 





Li LCD Controller 

— Supports Digital TFT and Passive LCD Panels 

— Horizontal Sync, Vertical Sync, Field and Blanking Timing Generation with 
Half-Clock Resolution and Programmable Polarity 

— 1-, 2-, or 4-Bit Per Pixel Grayscale Mode Using Advanced Frame Rate Control 
(FRC) Algorithm | 

— Four or Eight Bits Per Pixel Color Mode 

— 4-, 8-, 9-, or 12-Bit Parallel Output to LCD panel 

— Programmable Display Active Area 

— Non-Split or Vertically-Split Screen Support 

— Uses Burst Read DMA Cycles for Maximum Bus Penonnanes 

— End of Frame Interrupt Generation 

— Data for Splits—2+2 or 4+4 Parallel Bits (x+x Refers to x Bits Each - Lower 
and Upper Screens in Parallel) 

— Built-In Color RAM with 256 12-Bit Entries | 

— Programmable Wait Time Between Lines and Frames 

— Panel Voltage Control Adjustments for Contrast Set with On-Chip Timers 

_ — Programmable Polarity for All LCD Interface Signals 
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e Single-Socket PCMCIA-ATA Interface 

Master Interface, Release 2.1 Compliant 

Single PCMCIA Socket 

Eight Memory or I/O Windows Available 

Eight General-Purpose I/O Pins and Two General-Purpose Output-Only Pins are 
Available When the PCMCIA Controller Is Not in Operation 


e Low-Power Support Modes 


Oooo 
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4 Normal High—All Units Are Fully Powered at High Clock Frequency 

1 Normal Low—All Units Are Fully Powered at Low Clock Frequency 

1 Doze—Core Functional Units Are Disabled, Except Timebase, Decrementer, PLL, 
Memory Controller, Real-Time Clock, LCD, and Communication Processor Module 

[1 Sleep—All Units Are Disabled, Except Real-Time Clock, Periodic Interrupt Timer, 
Timebase, and Decrementer. PLL Is Active for Fast Wake-up 

1 Deep Sleep—All Units Are Disabled Including PLL, But Not the Real-Time Clock and 
Periodic Interrupt Timer, Timebase, and Decrementer 

LY Power-Down—All Units Are Disabled Including PLL, but Not the Real-Time Clock 
and Periodic Interrupt Timer, Timebase, and Decrementer. Saves More Power 
Than Other Modes. The State of Certain Registers May Be Preserved, 

1) Separate Power Supply Input to Operate Internal Logic at 2.2V At or Below 25MHz 
Operation 

1} Can Be Dynamically Shifted Between High Frequency (3.3V Internal) and Low 
Frequency (2.2V Internal) Operation 





Development Capabilities and Interface 


L} Program Flow Tracking 
— Instruction Show Cycle 
— Data Show Cycle 
— Branching 
— Exception Traps 
1 Watchpoints and Breakpoints 
— Four Hardware Breakpoints 
— Five Watchpoint Sources 
(1 Simple Hardware Interface 
_— High-Speed Data Transfer 
— Internal Status Pins 
— Freeze Indication 
L} Rich Control Register Set 


e¢ 3.3V Operation with 5V TTL Compatibility for the Parallel Port Pins and 3.3V for All 
Others. For Revision 0, All Pins are 5V TTL Compatible. 


e 256-Pin Plastic Ball Grid Array (BGA) Packaging 
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1.2 ARCHITECTURE 


The MPC823 microprocessor uses a dual-processor architecture design approach to 
provide you with a high-performance, general-purpose RISC integer processor and a 
special-purpose 32-bit scalar RISC communication processor module. The peripherals are 
uniquely designed for communication requirements and can provide embedded signal 
processing functions for communication and user interface enhancements and the I/O 
support needed for high-speed digital communications. The MPC823 is comprised of three 
main modules that interface with the 32-bit internal bus: 


e The embedded PowerPC core 

e The system interface unit 

e The communication processor module 
e LCD controller 


The MPC823 block diagram is illustrated in Figure 1-1. 
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1.2.1 The Embedded PowerPC Core 


The PowerPC core complies with standard PowerPC architecture. It has a fully static design 
that consists of three functional blocks—the integer block, hardware multiplier/divider, and 
load/store block. The core supports integer operations on a 32-bit internal data path and 
32-bit arithmetic hardware. Its interface to the internal and external buses is 32 bits. The 
core uses a two-instruction load/store queue, four-instruction prefetch queue, and a 
six-instruction history buffer. It performs branch folding and branch prediction with 
conditional prefetch, but without conditional execution. With single bus cycles, the core can 
operate on 32-bit external operands and with critical-word-first in multiple bus cycles. The 
PowerPC integer block supports 32 x 32-bit fixed-point general-purpose registers and can 
execute one integer instruction per clock cycle. 


The PowerPC core is integrated with the memory management units, an instruction cache, 
and a data cache. The memory management units (MMUs) provide 8-entry, fully-associative 
instruction and data TLBs, with multiple page sizes of 4K (1K protection), 16K, 512K, and 
8M. They support 16 virtual address spaces and 16 protection groups. Special registers are 
available to support software tablewalk and update. 


The instruction cache is 2K, two-way, set-associative with physical addressing. It allows 
single-cycle accesses on hit with no added latency for miss. It is four words per line and 
supports burst line fill using an LRU replacement algorithm. The cache can be locked ona 
line basis for application critical routines. The data cache is 1K, two-way, set-associative 
with physical addressing. It allows single-cycle accesses on hit with one added clock latency 
for miss. It has four words per line and supports burst line fill using an LRU replacement 
algorithm. The cache can be locked on a line basis for application critical data and can be 
programmed to support copyback or writethrough mode via the memory management unit. 
The cache-inhibit mode can be programmed per MMU page. The PowerPC core, with its 
instruction and data caches, can deliver approximately 66 MIPS at 50MHz (using Dhrystone 
2.1) or 115K Dhrystones, based on the assumption that it is issuing one instruction per cycle 
with a cache hit rate of 94%. 


1.2.2 The System Interface Unit 


The system interface unit supports traditional 68K big-endian memory systems, traditional 
x86 little-endian memory systems, and PowerPC little-endian memory systems. It also 
provides power management functions, reset control, a PowerPC decrementer, PowerPC 
timebase, and real-time clock. Although the PowerPC core is a 32-bit device internally, it can 
be configured to operate with an 8-, 16-, or 32-bit data bus. Regardless of the system bus 
size, dynamic bus sizing is supported, which allows 8-, 16-, and 32-bit peripherals and 
memory to coexist on a 32-bit system bus. 


The memory controller supports up to eight memory banks with glueless interfaces to 
DRAM, SRAM, EPROM, Flash EPROM, SDRAM, EDO and other peripherals with two-clock 
initial access to external SRAM and bursting support. It provides variable block sizes 
between 32K and 256M. The memory controller has 0 to 20 wait states for each bank of 
memory and can use address type matching to qualify each memory bank access. It 

provides four byte-enable signals for varying width devices, one output-enable signal, and 
~ one boot chip-select that is available at reset. 
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The DRAM interface supports 8-, 16-, and 32-bit ports and uses a programmable state 
machine to support almost any memory interface. Memory banks can be defined in depths 
of 256K, 512K, 1M, 2M, 4M, 8M, 16M, 32M, or 64M for all port sizes. In addition, the memory 
depth can be defined as 64K and 128K for 8-bit memory or 128M and 256M for 32-bit 
memory. The DRAM controller supports page mode access for successive transfers within 
bursts. The MPC823 supports a glueless interface to one bank of DRAM, while external 
buffers are required for additional memory banks. The refresh unit provides CAS before 
RAS, a programmable refresh timer, refresh active during external reset, disable refresh 
modes, and stacking for a maximum of seven refresh cycles. 


1.2.3 The Communication Processor Module 


The communication processor module (CPM) contains features that allow the MPC823 
microprocessor to excel in imaging, personal communication, and low-power applications. 
These features are divided into three categories: 7 


¢ DSP processing 
e Communication processing 
¢ Twelve serial DMA channels and two independent DMA channels 


The MPC823’s embedded DSP function allows the communication processor module to 
execute imaging algorithms in parallel with the PowerPC core to achieve maximum 
performance with very little power. The DSP can execute one 16x16 MAC on every clock 
cycle. It has preprogrammed filtering functions like FIR, MOD, DEMOD, IIR, and 
downloadable imaging functions for JPEG image compression and decompression. These 
functions are also used by modem and speech recognition programs. | 


The robust communication features of the MPC823 come from the communication _ 
processor module. These features include a RISC microcontroller with multiply accumulate 
(MAC) hardware, one serial communication controller (SCC), two serial management _ 
controllers (SMCs), one dedicated serial channel for the universal serial bus (USB), one 
inter-integrated circuit (I?C) port, one serial peripheral interface (SPI), 8K dual-port RAM, an 
interrupt controller, a time-slot assigner, and four independent baud rate generators. 


Twelve serial DMA channels support the SCC, SMCs, USB channel, SPI, and |@C 
controllers. The independent DMAs give you two channels for general-purpose DMA usage. 
They offer high-speed transfers, 32-bit data movement, buffer chaining, and independent 
request and acknowledge logic. The RISC microcontroller is the only block that can access 
the IDMA registers directly. The CPU can only access them indirectly via a buffer descriptor. 
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1.2.4 The Video/LCD Controller 


The MPC823 has a dual-purpose video/LCD controller that shares common dual-port 
memory. You can, however, only run one of the controllers at a time. 


1.2.4.1 THE VIDEO CONTROLLER. The video controller can be used to drive a digital 
NTSC/PAL encoder or a wide variety of digital LCD panels. The frame buffer is stored in 
system memory in the form of an orthogonal matrix—rows and columns. The 24-bit color 
data is organized as pixel components whether it is sequential RGB or YC,C». Each pixel 
component is represented by a byte. The video controller uses a dedicated DMA channel to 
read the display data from the frame buffer and drive it to the video interface. It also 
generates the required timing signals such as horizontal sync, vertical sync, field, and 
blanking. Refer to Section 19 Video Controller for more information. 


1.2.4.2 THE LCD CONTROLLER. The LCD controller provides extremely versatile LCD 
support for 8-bit color, monochrome or 4/16-level grayscale, color TFT (12 bits, 4x3 RGB), 
and passive color (xSTN) 4/8 bit data. The controller supports 4-bit single-scan, 8-bit dual- 
scan, 2+2 bit dual-scan, or 4+4 bit dual-scan. It is programmable for frame rate, number of 
pixels per line, and number of lines per frame. The panel voltage is programmable through 
the duty cycle for contrast adjustments implemented in the communication processor 
module program. Display data is stored in your own memory space and is transferred into 
the controller using the DMA channel. Refer to Section 18 LCD Controller for more 
information. 


1.3 THE PCMCIA-ATA CONTROLLER 


The PCMCIA-ATA interface is a master controller that is compliant with Version 2.1. The 
interface supports one independent PCMCIA socket with the required external transceivers 
or buffers. It provides eight memory or I/O windows that can be allocated to the socket. If 
the PCMCIA port is not being used as a card interface, it can provide eight general-purpose 
pins and two output-only pins with interrupt capability. 
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1.4 POWER MANAGEMENT 


The MPC823 microprocessor supports a wide range of power management features, 
including normal high, normal low, doze, sleep, deep-sleep, and power-down modes. In 
normal high mode, the MPC823 microprocessor is fully powered with all internal units 
operating at the full speed of the processor. Normal low mode is the same as normal high, 
except it operates at a much lower frequency. There is a doze mode determined by a clock 
divider that allows the operating system to reduce the operational frequency of the 
processor. 


Doze mode disables core functional units except the timebase, decrementer, PLL, memory 
controller, real-time clock, LCD controller, and communication processor module. Sleep 
mode is a lower power mode that disables everything except the real-time clock, timebase, 
decrementer, and periodic interrupt timer, thus leaving the PLL active for quick wake-up. 
The deep-sleep mode then disables the PLL for lower power, but slower wake-up. 
Power-down mode disables all logic in the processor, except the minimum logic required to 
restart the device. It saves the most power, but requires ine longest wake-up time. 


The MPC823 microprocessor also provides a separate set of power pins for the internal 
logic in the device. These power pins can be used to give the device a 2.2V power source 
that can be used when the microprocessor is operating at 25MHz or less. This capability 
reduces the power consumption of the device by an additional 30%. 


1.5 SYSTEM DEBUG SUPPORT 


The MPC823 microprocessor contains an advanced debug interface that provides superior 
debug capabilities without any loss of speed. It supports six watchpoint pins that can be 
combined with eight internal comparators, four of which operate on the effective address of 
the address bus. The other four comparators are split—two comparators operate on the 
effective address on the data bus and two comparators operate on the data on the data bus. 
The MPC823 microprocessor can compare using the =, #, <, and > conditions to generate 
watchpoints. Each watchpoint can then generate a breakpoint that can be programmed to 
trigger in a programmable number of events. 


1.6 APPLICATIONS 


The MPC823 microprocessor is specifically designed to be a general-purpose, low-cost 
entry point to the Motorola embedded PowerPC Family for systems in which advanced 
GUIs, communications, and high-level real-time operating systems are used. The device 
excels in applications that require the performance of single-issue PowerPC core with a 
moderate amount of data and instruction cache. It provides all the basic features of glueless 
memory connections along with highly functional serial connectivity, a graphical LCD, anda 
video display controller. The MPC823 excels in low-power and portable applications 
because of its extensive power-down modes and low normal operation current. 
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1.7 DIFFERENCES BETWEEN THE MPC823 AND MPC821 


The MPC823 is mostly a subset of the MPC821 microprocessor. To create the MPC823, the 
following modifications were made to the MPC821: 


e Instruction cache was reduced from 4K to 2K 
e Data cache was reduced from 4K to 1K 


Instruction and data MMUs were reduced from 32 to 8 TLB entries each 
e Pin count was reduced from 357 pins to 256 pins 

e Package size was reduced from 25mm (ZP) to 23mm (ZT) 

e Address bus was reduced from 32 bits to 26 bits 


Bisync protocol was removed from the serial communication controller 
e PCMCIA support was reduced to a single channel, PCMCIA channel B. 


One serial communication controller was removed from the CPM leaving a single 
channel (SCC2) 


e One USB channel was added to CPM in place of SCC1 

e High-speed IRDA support (1.152Mbps and 4Mbps) was added 
e Centronics protocol was removed 

e Video controller was added to support NTSC/PAL monitors 


1.8 MPC823 GLUELESS SYSTEM DESIGN 


The MPC823 was primarily designed to make it easy for you to interface a microprocessor 
with other system components. Figure 1-2 illustrates a system configuration that contains 
one flash EPROM and yet supports DRAM SIMM and one SRAM. Depending on the 
capacitance of the system bus, external buffers may be required. From a logic standpoint, 
however, a glueless system is maintained. 
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Figure 1-2. MPC823 System Configuration 
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SECTION 2 
EXTERNAL SIGNALS 


This section briefly describes each of the MPC823 input and output signals. 





























VDDSYN/VSSSYNVSSSYN1/VODH/VDDL/VSS/KAPWR 6 A[6:31]__ 
USBAXD/PA[15] 1 1 TSIZO/REG 
USBOE/PA(14] 1 1 TsIz1 
RXD2/PA(13] 1 1 RO/WR n 
TXD2/PAI 12] 1 1 BURST = 
SMRXD2/L1TXDA/PAI9] 1 1 BDIP/GPL_B5 e 
SMTXD2/L1RXDA/PAI8] 1 1 TS DB 
TIN1/LIRCLKA/BRGO1/CLK1/PA[7] 1 1 TA = 
TINS/TOUTI/CLK2/PA(6] 1 1 TEA = 
TIN2/L1TCLKA/BRGO2/CLK3/PA[5] 1 1 Bi oc 
TIN4/TOUT2/CLK4/PA[4] 1 1 iRQZ/RSV be 
LCD_A/SPISEL/PBI31} 1 1 IRQ4/KR/RETRY/SPKROUT fi 
SPICLK/PB[30] 1 
SPIMOSI/PB[29} 1 32 0(0:31] 
BRGO3/SPIMISO/PB[28} 1 4 DP(0:3/1RQI3:6] 
BRGO1/l2CSDA/PB[27] 1 1 BR 
BRGO2/l2CSCL/PBI26] 1 1 BG 
SMTXD1/PB[25] 1 1 BB ) 
SMRXD1/PB[24] 1 1 IROQG/FRZ | 
SMSYN1/SDACK1/PB[23] 1 2 TRO(O:1] 
SMSYN2/SDACK2/PB[22] 1 1 IRQ7 
LCD_B/L1ST1/PB[19] 1 6 CS(0:5 
LIST2V/RTS2/PB[18} 1 1 CS6/CE1_B 
LCD_C/L1ST3/PB[17] 1 1 CS7/CE2_B 
L1ST4/L1RQA/PB[16] 1 MPC823 1 WEO/BS_ABO/IORD 
LISTS/DREQI/PC(15) 1 1 WE1/BS_AB1/IOWR 
LIST62/RTS2/DREQ2/PC(14] 1 1 WE2/BS_AB2/PCOE. 
LIST7/PC[13} 1 1 WEQ/BS_AB3/PCWE 
LIST8/LIRQA/PC[12] 1 1 GPL_AO/GPL_BO 
USBRXP/PC{11] 1 1 GPL_A1/GPL_B1/0E 
USBRXN/TGATE1/PC[10] 1 2 GPL_A[2:3/GPL_B[2:3] 
CTS2/PC(9] 1 1 GPL_A4/UPWAITA/AS 
TGATE1/CD2/PC[8] 1 1 GPL_B4/UPWAITB 
USBTXP/PC{7] 1 1 GPL_AS 
USBTXN/PC{6} , 1 PORESET 
SDACK1/LITSYNCA/PC[5] 1 1 RSTCONF 
LIRSYNCA/PC[4} 1 1 HRESET 
LD8/VD7/PD[15] 1 1 SRESET 
LO7/VD6/PD[14} 1 1 XTAL 
LD6/VD5/PD([13] 1 1 EXTAL 
LDS/VD4/PD(12} 1 1 XFC | 
LD4/VD3/PD[11] 1 1 CLKOUT | 
LD3/VD2/PD{10} , 1 EXTCLK 
LO2/VD1/PD{9] 1 1 TEXP 
LD1/VD0/PD[8} 1 1 ALE_B/DSCK/AT1 
LDO/FIELD/PD[7] , 1 WAIT_B 
LCD_AC/LOE/BLANK/PD[6] 1 2 IP_B[0:1)/IWP[0:1/VFLS(0:1] 
FRAME/VSYNC/PO[5] 1 1 IP_B2/I0IS16_B/AT2 
LOAD/HSYNC/PD([4} 1 1 IP_BS/IWP2/VF2 
SHIFT/CLK/CLK/PD([3} 1 1 IP_B4/LWPO/VFO 
TS 1 1 IP_B5/LWP1/VF1 
TDVDSDI 1 1 IP_B6/DSDV/ATO 
TCK/DSCK 1 2 IP_B7/PTR/ATS _ 
TRST 1 1 MODCK1/OP2/STS 
TDO/DSDO 1 1 MODCK2/OP3/DSDO 





Figure 2-1. MPC823 Signal Pinout 
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External Signals 


2.1 THE SYSTEM BUS SIGNALS 


The MPC823 system bus signals consist of all the lines that interface with the external bus. 
Many of these lines perform different functions, depending on how you assign them. The 
following input and output signals are identified by their mnemonic name and each signal’s 
pin number can be found in Figure 2-1. 


Table 2-1. Signal Descriptions | | 


SIGNAL PIN NUMBER . DESCRIPTION 


- See Table 2-2 | Address Bus—This bidirectional three-state signal provides the address for the 
for pin current bus cycle. AO is the most-significant signal for this bus. The signal is output 
breakout. | when an internal master on the MPC823 initiates a transaction on the external bus. 
The signal is input when an external master initiates_a transaction on the bus and it 
is sampled internally to allow the memory controller/PCMCIA interface to control the 
accessed slave device. 



















Transfer Size 0O—When soceeeing a slave in the external bus, this three-state signal 
is used (together with TSIZ1) by the bus master to indicate the number of operand 
bytes waiting to be transferred in the current bus cycle. This signal is input when an 
external master initiates a transaction on the bus and it is sampled internally to allow 
the memory controller/PCMCIA interface to control the accessed slave device. 
REG—When the access is initiated by an internal master to a slave under control of 
the PCMCIA interface, this signal is output to indicate which space in the PCMCIA 
card is currently accessed. 



















Transfer Size 1—This three-state signal is used (with TSIZO) by the bus master to 

indicate the number of operand bytes waiting to be transferred in the current bus 

cycle. This signal is driven by the MPC823 when it is the owner of the bus. It is input 

when an external master initiates a transaction on the bus and it is sampled internally 

e allow the memory controller/PCMCIA interface to control the accessed slave 
evice. . 


SIVNDIS IWNYALX3 





Read Write—This three-state signal is driven by the bus master to indicate the _ 
direction of the bus’s data transfer. A logic one indicates a read from a slave device 
and a logic zero indicates a write to a slave device. This signal is driven by the 
MPC823 when it is the owner of the bus. It is input when an external master initiates 
a transaction on the bus and is sampled internally to allow the memory controller/ 
PCMCIA interface to control the accessed slave device. 











Burst Transaction—This three-state signal is driven by the bus master to indicate 
that the current initiated transfer is a burst one. This signal is driven by the MPC823 
when it is the owner of the bus. It is input when an external master initiates a 
transaction on the bus; this signal and is sampled internally to allow the memory 
controller/PCMCIA interface to control the accessed slave device. 






Burst Data in Progress—When accessing a slave device in the external bus, the 
master on the bus asserts this signal to indicate that the data beat in front of the 
current one is the one requested by the master. This signal is negated prior to the 
expected last data beat of the burst transfer. 


General-Purpose Line B5—This signal is used by the memory controller when the 
user programmable machine B (UPMB) takes control of the slave access. 

















Transfer Start—This three-state siqng is asserted by the bus master to indicate the 
| start of a bus cycle that transfers data to or froma slave device. This signal is driven 
by the master Soywen it has gained ownership of the bus. Every master should 
Ae ake this signal before the bus relinquishes. A pull-up resistor should be connected 
to this signal to prevent a slave device from detecting a spurious bus accessing it 
when no master is taking ownership of the bus. 

This signal is sampled by the MPC823 when it is not the owner of the external bus 
to allow the memory controller/PCMCIA interface to control the accessed slave 
device. It indicates that an external synchronous master initiated a transaction. 


2-2 MPC823 USER’S MANUAL MOTOROLA 


External Signals 


Table 2-1. Signal Descriptions (Continued) 


SIGNAL PIN NUMBER DESCRIPTION 
TA 


Transfer Acknowledge— This bidirectional three-state signal indicates that the 
slave device addressed in the current transaction has accepted the data transferred 
by the master (write) or has driven the data bus with valid data (read). The signal 
behaves as an output when the PCMCIA memory controller takes control of the 
transaction. The only exception occurs when the memory controller is controlling the 
slave access by means of the GPCM and the corresponding option register is 
instructed to wait for an external assertion of the transfer ac pewecde line. Every 
slave device should negate the ta signal after the end of the transaction and | 
immediately three-state it to avoid contentions on the line if a new transfer is initiated 
addressing other slave devices. A paeue resistor should be connected to this signal 
to keep a master device from detecting the assertion of this signal when no slave is 
ae ee ee in a transfer or when the address detection for the addressed slave is 
slow. 



























Transfer Error Acknowledge—This open-drain signal indicates that a bus error 
occurred in the current transaction. Itis driven asserted by the MPC823 when the bus 
monitor does not_detect a bus cycle termination within a reasonable amount of time. 
ie aesetlon: of TEA causes the termination of the current bus cycle, thus ignoring 

e state of TA. 














Burst Inhibit—This bidirectional three-state signal indicates that the slave device 
addressed in the current burst transaction is unable to support burst transfers. The 
signal behaves as an output when the PCMCIA memory controller takes control of 
the transaction. When the MPC823 drives out the signal for a specific transaction, it 
asserts or negates BI during the transaction according to the value you specify in the 
appropriate control registers. It negates the signal after the end of the transaction 
and immediately three-states it to avoid contentions if a new transfer is initiated 
addressing other slave devices. 

















Reservation—This three-state signal is output by the MPC823 in conjunction with 
the address bus to indicate that the internal core initiated a transfer as a result of a 
stwex or Iwarx instruction. 


Interrupt Request 2— This input is one of the eight external signals that can request 
(by means of the internal interrupt controller) a service routine from the core. 














tenure Request 4—This input signal is one of the eight external signals that can 
request (by means of the internal interrupt contoneia service routine from the core. 
It should be noted that the interrupt request signal that is sent to the interrupt 
controller is the logical AND of this saan" defined to function as IRQ4) and the 


DP1/IRQ4 (if defined to function as 
Kill Reservation—This input is used as a part of the storage reservation protocol 
when the MPC823 initiated a transaction as the result of a stwex instruction. 
Retry—This input is used by the slave device to indicate that it is unable to accept 
the transaction. The MPC823 has to relinquish the ownership of the bus and initiate 
the transaction again after winning again in the bus arbitration. 

Speaker Out—This output signal is used to provide a digital audio waveform to be 
driven to the system’s speaker. 
















SPKROUT 


















See Table 2-2 
for pin 
breakout. 


Data Bus—This bidirectional three-state signal provides the general-purpose data 
path between the MPC823 and all other devices. Although the data pathisa_ 
maximum of 32 bits wide, it can be dynamically sized to support 8-, 16-, or 32-bit 
transfers. DO is the most-significant bit of the data bus. 












_| Data Parity O—This bidirectional three-state signal provides parity generation and 
tees for the data bus lane D[0:7] by transferring to a slave device initiated by the 
MPC823. The parity function can be defined independently for each one of the 

addressed memory banks uf controlled by the memory controller) and for the rest of 

the slaves sitting on the external bus. | 


Interrupt Request 3—This input signal is one of the eight external signals that can 
request (by means of the internal interrupt controller) a service routine from the core. 













Data Parity 1—This bidirectional three-state as provides Paty generation and 

eb lve for the data bus lane D[8:15] by transferring to a slave device initiated by 

the MPC823. The parity function can be defined nese nee for each one of the 

addressed memory banks (if controlled by the memory controller) and for the rest of 
the slaves on the external bus. 


Interrupt Request 4— This input is one of the eight external lines that can request 
(by means of the internal interrupt controller) a service routine from the core. It snould 
be noted that the interrupt request signal that is sentto the interrupt controller is the 
logical AND of this signal (if defined to function as IRQ4) and the KR/SPKROUT/ 

IRQ4 if defined to function as IRQ4. 
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External Signals 


Table 2-1. Signal Descriptions (Continued) 


SIGNAL PIN NUMBER DESCRIPTION. 
3 


D Data Parity 2—This bidirectional three-state signal provides parity generation and 

read for the data bus lane D[16:23] Py transferring to a slave device initiated by 
the MPC823. The parity function can be defined inespendenty for each one of the 

addressed memory banks (if controlled by the memory controller) and for the rest of 
the slaves on the external bus. 


Interrupt Request 5—This input signal is one of the eight external signals that can 
request (by means of the internal interrupt controller) a service routine from the core. 

























Data Parity 3—This bidirectional three-state signal provides parity generation and 
checking for the data bus lane D[24:31] by transferring to a slave device initiated by 
the MPC823. The parity function can be defined ncepe cent for each one of the 
addressed memory banks (if controlled by the memory controller) and for the rest of 
the slaves on the external bus. 


Interrupt Request 6—This input signal is one of the eight external signals that can 
request (by means of the internal interrupt eoneleue service routine from the core. 
It should be noted that the interrupt request signal that is sent to the interrupt 
controller is the logical AND of this signal (if defined to function as IRQ6) and the 
FRZ/IRQ6 if defined to function as IRQ6. 

























Bus Request—This bidirectional signal is asserted low when a possible master is 
requesting ownership of the bus. When the MPC823 is configured to operate with the 
internal arbiter, this signal is configured as an input. However, when the MPC823 is 
configured to operate with an external arbiter, this signal is configured as an output 
and asserted every time a new transaction is intended to be initiated and no parking 
on the bus is granted. 







Bus Grant—This bidirectional signal is asserted low when the arbiter of the external 
bus grants the specific master ownership of the bus. When the MPC823 is 
configured to operate with the internal arbiter, this signal is configured as an output 
and asserted Eve time the external master asserts the BR signal and its priority 
request is higher than any of the internal sources requiring the initiation of a bus 
transfer. However, when the MPC823 is configured to operate with an external 
arbiter, this signal is configured as an input. 







Bus ae bidirectional signal is asserted low by a master to show that it owns 
the bus. The MPC823 asserts this signal after the bus arbiter grants it bus ownership 
and the BB signal is negated. 













Interrupt Request 6—This input signal is one of the eight external signals that can 
request (by means of the internal interrupt Souci ba service routine from the core. 
It should be noted that the interrupt request signal that is sent to the_interrupt 
controller is the logical AND of this signal (if defined to function as IRQ6) and the 
DP3/IRQ6 (if defined to function as IRQ6.) 

Soe output signal is asserted to indicate that the internal core is in debug 
mode. 






Interrupt Request 0—This input signal is one of the eight external signals that can 
request (by means of the internal interrupt controller) a service routine from the core. 


IRQ1 N2 Interrupt Request 1—This input signal is one of the eight external sdnels that can 
request (by means of the internal interrupt controller) a service routine from the core. 
IRQ7 ~ NS Interrupt Request 7—This input signal is one of the eight external signals that can 
request (by means of the internal interrupt controller) a service routine from the core. 








See Table 2-2 | Chip Select—These output signals enable peripheral or memory devices at 
for pin pegammed addresses if they are appropriately defined in the memory controller. 
breakout. | CS0 can be configured to be the global chip-select for the boot device. 











Chip Select 6—This output signal enables a peripheral or memory device at a 
pro armed address if defined appropriately in the BR6 and OR6 of the memory 
controller. 


Card Enable 1 Slot B—This output signal enables even aye transfers when 
accesses to the PCMCIA Slot B are handled by the PCMCIA interface. 
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Table 2-1. Signal Descriptions (Continued) 


SIGNAL PIN NUMBER DESCRIPTION 


Chip Select 7—This hee signal enables a peripheral or memory device at a 
programmed address if defined appropriately in the BR7 and OR7 registers of the 
memory controller. 

Card Enable 2 Slot B—This output signal enables odd byte transfers when 
accesses to the PCMCIA Slot B are handled by the PCMCIA interface. 


Write Enable 0—This output signal is asserted when a write access to an external 

slave controlled by the GPCM in the memory controller is initiated by the MPC823. 

ihe is asserted if the data lane D[0:7] contains valid data to be stored by the slave 
evice. 

Byte Select 0 on UPMA or UPMB—This output signal is asserted as required by the 

UPMA or UPMB in the memory controller whenever you program it. In a read or write 

transfer, the signal is only asserted if the data lane D[0:7] contains valid data. 


I/O Device Read—This output doe is asserted when the MPC823 initiates a read 
access to a region controlled by the PCMCIA interface. The signal is only asserted if 
the access is to a PC Card I/O space. 


Write Enable 1—This output signal is asserted when the MPC823 initiates a write_ 

access to an external slave controlled by the GPCM in the momen controller. WE1 

' asserted if the data lane D[8:15] contains valid data to be stored by the slave 
evice. 


aay. Select 1 on UPMA or UPMB—This output signal is asserted as required by the 
UPMA or UPMB in the memory controller whenever you program it. In a read or write 
transfer, the signal is only asserted if the data lane D[8:15] contains valid data. 

1/0 Device Write—This output signal is asserted when the MPC823 initiates a write 
access to a region controlled by the PCMCIA interface. The signal is only asserted if 
the access is to a PC Card I/O space. 
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Write Enable 2—This output Sane is asserted when the MPC823 initiates a write 
access to an external slave controlled by the GPCM in the memory controller. WE2 
‘ asserted if the data lane D[16:23] contains valid data to be stored by the slave 
evice. 

Byte Select 2 on UPMA or UPMB—This output signal is asserted as required by the 
UPMA or UPMB in the memory controller whenever you rogram it. In a read or write 
transfer, the signal is only asserted if the data lane D[16:23] contains valid data. 
PCMCIA Output Enable—This output signal is asserted when the MPC823 initiates 
a read access to a memory region under the control of the PCMCIA interface. 


e 





Write Enable 3—This output signal is asserted when the MPC823 initiates a write_ 
access to an external slave controlled by the GPCM in the memory controller. WE3 
: asserted if the data lane D[24:31] contains valid data to be stored by the slave 
evice. 

Byte Select 3 on UPMA or UPMB—This output signal is asserted as required by the 
UPMA or UPMB in the memory controller whenever you program it. In a read or write 
transfer, the signal is only asserted if the data lane D[24:31] contains valid data. 
PCMCIA Write Enable—This output signal is asserted when the MPC823 initiates a 
write access to a memory region controlled by the PCMCIA interface. 


General-Purpose Line 0 on UPMA—This output signal reflects the value specified 
in the UPMA in the memory controller when an external transfer to a slave is 
controlled by the user programmable machine A (UPMA). 

General-Purpose Line 0 on UPMB—This output signal reflects the value specified 
in the UPMB in the memory controller when an external transfer to a slave is 
controlled by the user programmable machine B (UPMB). 


General-Purpose Line 1 on UPMA—This output signal reflects the value specified 
in the UPMA in the memory controller when an external transfer to a slave is 
controlled by the user programmable machine A (UPMA). 

General-Purpose Line 1 on UPMB—This output signal reflects the value specified 
in the UPMB in the memory controller when an external transfer to a slave is 
controlled by the user programmable machine B (UPMB). 


Output Enable—This output signal is asserted when the MPC823 initiates a read 
access to an external slave controlled by the GPCM in the memory controller. 
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External Signals 


Table 2-1. Signal Descriptions (Continued) 


SIGNAL PIN NUMBER | - DESCRIPTION % 4 7 


General-Purpose Line 2 on UPMA—This output signal reflects the value specified 
-|in the UPMA in the memory controller when an external transfer to a slave is 
controlled by the user programmable machine A (UPMA). 


General-Purpose Line 2 on UPMB—This output signal reflects the value specified 
in the UPMB in the memory controller when an external transfer to a slave is 
controlled by the user programmable machine B (UPMB). 

Chip Select 2—This output signal enables a peripheral or memory device at a 
programmed address if defined appropriately in the BR6 and OR6 registers of the 
memory controller. 
























General-Purpose Line 3 on UPMA—This output signal reflects the value specified 
in the UPMA in the memory controller when an external transfer to a slave is 
controlled by the user programmable machine A (UPMA). 


General-Purpose Line 3 on UPMB—This output signal reflects the value specified 
in the UPMB in the memory controller when an external transfer to a slave Is 
controlled by the user programmable machine B (UPMB). 

Chip Select 3—This output signal enables a peripheral or memory device at a 
programmed address if defined appropriately in the BR6 and OR6 registers of the 
memory controller. 







GPL_A4 
UPWAITA 
AS 


General-Purpose Line 4 on UPMA—This output signal reflects the value specified 
in the UPMA in the memory controller when an external transfer to a slave is 
controlled by the user programmable machine A (UPMA). 


User Programmable Machine Wait A—This input signal is sat te when you need 
it an ioe an access to an external slave is controlled by the UPMA in the memory 
controller. 


Address Strobe—This input pin is driven by an external asynchronous master to 
indicate a valid address on the ea lines. The memory controller in the MPC823 
will synchronize this signal and control the memory device addressed if it is 
recognized to be under its control. 

















GPL_B4 Bi3 
UPWAITB 





General-Purpose Line 4 on UPMB—This output signal reflects the value specified 
in the UPMB in the memory controller when an external transfer to a slave is 
controlled by the user programmable machine B (UPMB). 

User Programmable Machine Wait B—This input signal is ah oa when you need 
it ane ti an access to an external slave is controlled by the UPMB in the memory 
controller. | 









General-Purpose Line 5 on UPMA—This output signal reflects the value specified 
in the UPMA in the memory controller when an external transfer to a slave Is 
controlled by the user programmable machine A (UPMA). This signal can also be 
controlled by the UPMB. 


PORESET | - Power-On Reset—When asserted, this input signal causes the MPC823 to enter the 
power-on reset state. , 


B3 
RSTCONF C5 Reset Configuration—This input signal is sampled by the MPC823 during the 
assertion of the HRESET signal. If it is asserted, the configuration mode is sampled 
in the form of the hard reset configuration word driven on the data bus. When this 
signal is negated, the default configuration mode is adopted by the MPC823. Notice 
that the initial base address of internal registers is determined in this sequence. 


GPL_A5 | C12 













HRESET ard Reset—This open drain line, when asserted, causes the MPC823 to enter the 
rd reset state. 


H 
ha 


BS 
SRESET 4 


B Soft Reset—This open drain line, when asserted, causes the MPC823 to enter the 


soft reset state. 


XTAL A4 External Crystal—This output signal is one of the connections to an external crystal 


for the internal oscillator circuitry. 


EXTAL a! ANS External Crystal—This signal is one of the connections to an external crystal for the 


{internal oscillator circuitry. 


External Filter ha Ser est input signal is the connection pin to an external 


capacitor filter for the PLL circuitry. 


D1 CLKOUT—This output signal is the clock system frequency. 
A6 External Clock—This input signal is the external input clock from an external 
source. 
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External Signals 


Table 2-1. Signal Descriptions (Continued) 


SIGNAL PIN NUMBER | DESCRIPTION 
TEXP D5 Timer Expired—tThis output signal reflects the status of the TEXPS bit of the 
PLPRCR register in the clock interface. 
WAIT_B C4 Wait Slot B—This input signal, if asserted low, causes the completion of a 
| transaction to be delayed on the PCMCIA-controlled Slot B. 


ALE_B B8 Address Latch Enable B—This output signal is asserted when the MPC823 
DSCK initiates an access to a region under the control of the PCMCIA socket B interface. 
neve opment Serial Clock—This input signal is the clock for the debug port 
interface. 

Address Type 1—This bidirectional three-state signal is driven by the MPC823 
when it initiates a transaction on the external bus. When the transaction is initiated 
by the internal core, it indicates if the transfer is for problem or privilege state. 







































Input Port B 0—This input signal is sensed by the MPC823 and its value and 
changes are reported in the PIPR and PSCR registers of the PCMCIA interface. 
Instruction Watchpoint 0—This output signal reports the detection of an instruction 
watchpoint in the program flow executed by the internal core. 

Visible History Buffer Flushes Status—This output signal is output by the MPC823 
when you need program instructions flow tracking. It reports the number of 
instructions flushed from the history buffer in the internal core. 





Input Port B 1—This input signal is sensed by the MPC823 and its value and 
changes are reported in the PIPR and PSCR registers of the PCMCIA interface. 
Instruction Watchpoint 1— This output signal reports the detection of an instruction 
watchpoint in the program flow executed by the internal core. 

Visible History Buffer Flushes Status—This output signal is output by the MPC823 
when you need program instructions flow tracking. It reports the number of 
instructions flushed from the history buffer in the internal core. 

















Input Port B 2—This input signal is sensed by the MPC823 and its value and 
changes are reported in the PIPR and PSCR registers of the PCMCIA interface. 
I/O Device B is 16 Bits Port Size—This input signal is monitored by the MPC823 
when a PCMCIA interface transaction is initiated to an I/O region in socket B within 
the PCMCIA space. 

Address Type 2—This bidirectional three-state signal is driven by the MPC823 
when it initiates a transaction on the external bus. When the transaction is initiated 
by the internal core, it indicates if the transfer is instruction or data. 






lOlIS16_B 
AT2 











Input Port B 3—This input signal is monitored by the MPC823 and its value and 
changes are reported in the PIPR and PSCR registers of the PCMCIA interface. 
Instruction Watchpoint 2—This output signal reports the detection of an instruction 
watchpoint in the program flow executed by the internal core. 


Visible Instruction Queue Flush Status—This output signal, together with VFO and 
VF1, is output by the MPC823 when you need program instruction (ow tae: VFx 
reports the number of instructions flushed from the instruction queue in the internal 
core. 


Input Port B 4—This input signal is monitored by the MPC823 and its value and 
changes are reported in the PIPR and PSCR registers of the PCMCIA interface. 
Load/Store Watchpoint 0—This output signal reports the detection of a data 
watchpoint in the program flow executed by the internal core. 


Visible Instruction Queue Flushes Status—This output signal, together with VF 1 

and VF2, is output by the MPC823 when joe need program instructions flow 

Tagang As reports the number of instructions flushed from the instruction queue in 
e internal core. 



















Input Port B 5—This input signal is monitored by the MPC823 and its value and 
changes are reported in the PIPR and PSCR registers of the PCMCIA interface. 
Load/Store Watchpoint 1—This output signal reports the detection of a data 
watchpoint in the program flow executed by the internal core. 
Visible Instruction Queue Flushes Status—This output signal, together with VFO 
and VF2, is output by the MPC823 when yeu need program instructions flow 
tageng: Mi reports the number of instructions flushed from the instruction queue in 
e internal core. | 
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External Signals 


Table 2-1. Signal Descriptions (Continued) 


SIGNAL PIN NUMBER DESCRIPTION | 


Input Port B 6—This input si nal is sensed by the MPC823 and its value and 
changes are reported in the PIPR and PSCR registers of the PCMCIA interface. 
peveropment Serial Data Input—This input signal is the data in for the debug port 
interface. 2 

Address Type 0—This bidirectional three-state se is driven by the MPC823 
when it initiates a transaction on the external bus. If high (1), the fransaction is the 
CPM. If low (0), the transaction initiator is the core. 









©) 
N 





IP_B7 


Input Port B 7—This input signal is monitored by the MPC823 and its value and 
PTR changes are reported in the PIPR and PSCR registers of the PCMCIA interface. 
AT3 Program Trace—This output signal is asserted by the MPC823 to indicate that an 
instruction fetch is taking place in order to allow program flow tracking. 
Address Type 3—This bidirectional three-state signal is driven by the MPC823 
when it initiates a transaction on the external bus. When the transaction is initiated 
by the internal core, it indicates if the transfer is reserved for data transfers or a 
= program trace indication for instructions fetch. 
MODCK1 Mode Clock 1—This input signal is sampled at PORESET negation to configure the 
| OP2 PLL/clock mode of operation. 
te STS Output Port 2—This output signal is generated by the MPC823 as a result of a write 


to the PGCRB register in the PCMCIA interface. 


Special Transfer Start—This output signal is driven by the MPC823 to indicate the 
Senn of a transaction on the external bus or an internal transaction in show cycle 
mode. 


MODCK2 
OP3 
DSDO 


Mode Clock 2—This input signal is sampled at PORESET negation to configure the 
PLL/clock mode of operation. 

Output Port 3—This output signal is generated by the MPC823 as a result of a write 
to the PGCRB register in the. PCMCIA interface. | 

Development Serial Data Output—This output signal is the data out of the debug 
port interface. 
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General-Purpose I/O Port A Bit 15—Bit 15 of the general-purpose I/O port A. 


PA[15] — P16 
USBRXD USBRXD—The receive data input signal for the USB. 
PA[14] R15 General-Purpose I/O Port A Bit 14—Bit 14 of the general-purpose I/O port A. 
USBOE USBOE—The output enable signal for the USB transmitter. 
~PA[13] R14 General-Purpose I/O Port A Bit 13—Bit 13 of the general-purpose I/O port A. 
RXD2 RXD2—The receive data input signal for the serial communication controller. 
PA[12] 
TXD2 


PA[9] 
LITXDA 
SMRXD2 








General-Purpose I/O Port A Bit 12—Bit 12 of the general-purpose 1/O port A. 


TXD2—The transmit data output signal for the serial communication controller. 
TXD2 has open-drain capability. 








General-Purpose I/O Port A Bit 11—Bit 9 of the general-purpose !/O port A. 


L1TXDA—The transmit data output signal for the serial interface time-division 
multiplex port A. This signal has open-drain capability. 


SMRXD2—The serial management controller 2 receive data pin. 


R13 
N10 








4 
i<e) 


(oe) 


PA[8] | 
LiRXDA 
SMTXD2 © 


General-Purpose I/O Port A Bit 8—Bit 8 of the general-purpose 1/O port A. 


L1RXDA—The receive data input signal for the serial interface time-division 
multiplex port A. 


SMTXD2—The serial management controller 2 transmit data pin. 





PA[7] 
CLK1 


General-Purpose I/O Port A Bit 7—Bit 7 of the general-purpose I/O port A. 


CLK1—This input signal is one of the four clock pins that can be used to clock the 
serial communication controller, serial management controllers, and USB. 


TIN1—The timer 1 external clock pin. 
L1RCLKA—The receive clock for the serial interface time-division multiplex port A. 
BRGO1—The output clock of BRG1. 


TIN 
L1RCLKA 
BRGO1 








PA[6] 
CLK2 | 
TOUT1 
TIN3 


General-Purpose I/O Port A Bit 6—Bit 6 of the general-purpose |/O port A. 


CLK2—This input signal is one of the four clock pins that can be used to clock the 
serial communication controller, serial management controllers, and USB. 


TOUT1—The timer 1 output pin. 
TIN3—The timer 3 external clock pin. 
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External Signals 


Table 2-1. Signal Descriptions (Continued) 


SIGNAL PIN NUMBER DESCRIPTION 
T6 


PA[5] General-Purpose 1/O Port A Bit 5—Bit 5 of the general-purpose I/O port A. 


CLK3 CLK3—This input signal is one of the four clock pins that can be used to clock the 
TIN2 serial communication controller, serial management controllers, and USB. 


LiITCLKA TIN2—The timer 2 external clock input pin. 
BRGO2 L1TCLKA—The transmit clock for the serial interface time-division multiplex port A. 
BRGO2—The output clock of BRG2. 

































General-Purpose I/O Port A Bit 4—Bit 4 of the general-purpose I/O port A. 


CLK4—This input signal is one of the four clock pins that can be used to clock the 
serial communication controller, serial management controllers, and USB. 


TOUT2—The timer 2 output pin. 
TIN4—The timer 4 external clock pin. 
























PB[31] General-Purpose I/O Port B Bit 31—Bit 31 of the general-purpose I/O port B. 
SPISEL SPISEL—The serial peripheral interface slave select input pin. 
LCD_A LCD _A—tThis is one of the LCD controller's three extension data bits, which are 





used to drive an active LCD panel. When using a 12-bit bus instead of a 9-bit bus, 
the LCD_A signal is the leas Sonica bit of the red 4-bit code. The red portion of 
the bus consists of LD[0:2] and LCD_A. 




























PB[30] P15 General-Purpose I/O Port B Bit 30—Bit 30 of the general-purpose I/O port B. 
SPICLK SPICLK—The serial ponpnera interface output clock when it is configured as a 
master or serial peripheral interface input clock when it is configured as a slave. 

PB[29] P14 General-Purpose I/O Port B Bit 29—Bit 29 of the general-purpose I/O port B. 
SPIMOS! SPIMOSI—The serial peripheral interface output data when it is configured as a 





master or serial peripheral interface input data when it is configured as a slave. 




















PB[28] 
SPIMISO 
BRGO3 


General-Purpose I/O Port B Bit 28—Bit 28 of the general-purpose 1/O port B. 


SPIMISO—The serial peripheral interface ye data when it is configured as a 
master or serial peripheral interface output data when it is configured as a slave. 


BRGO3—The output clock of BRGS. 


















PB[27] General-Purpose I/O Port B Bit 27—Bit 27 of the general-purpose I/O port B. 
I2CSDA I2CSDA—The |°C serial data pin. This pin is bidirectional and should be configured 
BRGO1 as an open-drain output. 





BRGO1—The output clock of BRG1. 






















PB[26] 
I2CSCL 
BRGO2 


General-Purpose I/O Port B Bit 26—Bit 26 of the general-purpose I/O port B. 


I2CSCL—The IC serial clock pin. This pin is bidirectional and should be configured 
as an open-drain output. 


BRGO2—The output clock of BRG2. 
PB[25] N11 General-Purpose I/O Port B Bit 25—Bit 25 of the general-purpose 1/O port B. 
SMTXD1 SMTXD1—The serial management controller 1 transmit data output pin. 


PB[24] | General-Purpose I/O Port B Bit 24—Bit 24 of the general-purpose I/O port B. 
SMRXD1 SMRXD1—The serial management controller 1 receive data input pin. 


























PB[23] T10 General-Purpose I/O Port B Bit 23—Bit 23 of the general-purpose 1/O port B. 
SMSYN1 SMSYN1—The serial management controller 1 external sync input pin. 
SDACK1 SDACK1i—The SDMA acknowledge 1 output pin that is used as a peripheral 





interface signal for IDMA emulation or as a CAM interface signal for Ethernet. 









General-Purpose I/O Port B Bit 22—Bit 22 of the general-purpose |/O port B. 
SMSYN2—The serial management controller 2 external sync input pin. 


SDACK2—The SDMA acknowledge 2 output pin that is used as a pelea 
interface signal for IDMA emulation or as a CAM interface signal for Ethernet. 











PB[22] 
SMSYN2 
SDACK2 
' _ 


L1ST1 
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General-Purpose I/O Port B Bit 19—Bit 19 of the general-purpose I/O port B. 
L1ST1—One of eight output strobes that can be generated by the serial interface. 
LCD_B—This is one of the LCD controller's three extension data bits, which are 
used to drive an active LCD panel. When using a 12-bit bus instead of a 9-bit bus, 
the LCD_B signal is the least-significant bit of the green 4-bit code. The green portion 
of the bus consists of LD[3:5] and LCD_B. 
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External Signals 


Table 2-1. Signal Descriptions (Continued) 


SIGNAL PIN NUMBER DESCRIPTION 
P7 


PB[18] General-Purpose I/O Port B Bit 18—Bit 18 of the general-purpose I/O port B. 
RTS2 
L1iST2 


RTS2—The Request To Send modem signal for the serial communication controller. 
L1ST2—One of eight output strobes that can be generated by the serial interface. 

PB[17] N7 

LIST3 

LCD_C 

PB[16] R5 
L1RQA 
L1iST4 




























General-Purpose I/O Port B Bit 17—Bit 17 of the general-purpose I/O port B. 
L1ST3—One of eight output strobes that can be generated by the serial interface. 
LCD_C—This is one of the LCD controller's three extension data bits, which are 

used to drive an active LCD panel. When Sing a 12-bit bus instead of a 9-bit bus, 
the LCD_C signal is the least-significant bit of the blue 4-bit code. The blue portion 
of the bus consists of LD[6:8] and LCD_C. 





General-Purpose I/O Port B Bit 16—Bit 16 of the general-purpose |/O port B. 


L1 ee D-channel request signal for the serial interface time-division multiplex 
port A. 


L1ST4—One of eight output strobes that can be generated by the serial interface. 












R16 General-Purpose I/O Port C Bit 15—Bit 15 of the general-purpose I/O port C. 
DREQ1—The IDMA channel 1 request input signal. 
L1ST5—One of eight output strobes that can be generated by the serial interface. 
T16 General-Purpose I/O Port C Bit 14—Bit 14 of the general-purpose I/O port C. 





DREQ2—The IDMA channel 2 request input signal. 
RTS2—The Request To Send modem signal for the serial communication controller. 
L1ST6—One of eight output strobes that can be generated by the serial interface. 



















PC[12] 
LIRQA 
L1ST8 


General-Purpose I/O Port C Bit 12—Bit 12 of the general-purpose I/O port C. 


L1 Soe D-channel request signal for the serial interface time-division multiplex 
port A. 


L1ST8—One of eight output strobes that can be generated by the serial interface. 





PC[11] R10 
USBRXP 


General-Purpose I/O Port C Bit 11—Bit 11 of the general-purpose I/O port C. 


USBRXP—Used with USBRXN, this signal is used by the USB to detect a 
single-ended zero and the interconnection speed. | 







PC[10] 
TGATE1 
USBRXN 


General-Purpose I/O Port C Bit 10—Bit 10 of the general-purpose |/O port C. 
TGATE1—The timer1/timer2 gate signal. 


USBRXN—Used with USBRXP, this signal is used by the USB to detect a 
single-ended zero and the interconnection speed. 
























General-Purpose I/O Port C Bit 9—Bit 9 of the general-purpose 1/O port C. 
CTS2—The Clear to Send Modem line for the serial communication controller. 





General-Purpose I/O Port C Bit 8—Bit 8 of the general-purpose I/O port C. 
CD2—The Carrier Detect Modem line for the serial communication controller. 
TGATE1—The timer1/timer2 gate signal. 






General-Purpose I/O Port C Bit 7—Bit 7 of the general-purpose I/O port C. 


Ronee output signal, in conjunction with USBTXN, are the transmit lines of 
e 





General-Purpose I/O Port C Bit 6—Bit 6 of the general-purpose I/O port C. 


ee output signal, in conjunction with USBTXP, are the transmit lines of 
e 











General-Purpose I/O Port C Bit 5—Bit 5 of the general-purpose I/O port C. 


L1 ene ne transmit sync input for the serial interface time-division multiplex 
port A. 


SDACK1—The SDMA acknowledge 1 output pin that is used as a peripheral 
interface signal for IDMA emulation or as a CAM interface signal for Ethernet. 







LITSYNCA 
SDACK1 











PC[4] 
LIRSYNCA 


General-Purpose I/O Port C Bit 4—Bit 4 of the general-purpose I/O port C. 


L1 Bae ne receive sync input for the serial interface time-division multiplex 
port A. 
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External Signals 


Table 2-1. Signal Descriptions (Continued) 


SIGNAL PIN NUMBER DESCRIPTION 


PD[15] R4 General-Purpose I/O Port D Bit 15—Bit 15 of the general-purpose I/O port D. 
LD8 
VD7 
T3 









LD8—One of the 12 data bus bits used to drive the LCD panel. 


ita lated of the data bus bits of the video controller used for driving the video 
encoder. 






PD[14] General-Purpose I/O Port D Bit 14—Bit 14 of the general-purpose I/O port D. 
LD7 LD7—One of the 12 data bus bits used to drive the LCD panel. 
VD6 VD6—One of the data bus bits of the video controller used for driving the video 






encoder. 








PD[13] 
LD6 
VD5 


PD[12] R3 
LD5 
VD4 
PD[11] N5 
LD4 
VD3 
PD[10] T2 
LD3 : 
VD2 
PD[9] P4 
LD2 
VD1 
PD[8] TH 
LD1 
vDO 


General-Purpose I/O Port D Bit 13—Bit 13 of the general-purpose I/O port D. 
LD6—One of the 12 data bus bits used to drive the LCD panel. 


VD5—One of the data bus bits of the video controller used for driving the video 
encoder. 












General-Purpose I/O Port D Bit 12—Bit 12 of the general-purpose |/O port D. 
LD5—One of the 12 data bus bits used to drive the LCD panel. 


VD4—One of the data bus bits of the video controller used for driving the video 
encoder. 







General-Purpose I/O Port D Bit 11—Bit 11 of the general-purpose I/O port D. 
LD4—One of the 12 data bus bits used to drive the LCD panel. 


Mees of the data bus bits of the video controller used for driving the video 
encoder. 











General-Purpose I/O Port D Bit 10—Bit 10 of the general-purpose I/O port D. 
LD3—One of the 12 data bus bits used to drive the LCD panel. 


Mariel of the data bus bits of the video controller used for driving the video 
encoder. 









General-Purpose I/O Port D Bit 9—Bit 9 of the general-purpose I/O port D. 
LD2—One of the 12 data bus bits used to drive the LCD panel. 


od aed of the data bus bits of the video controller used for driving the video 
encoder. 












General-Purpose !/O Port D Bit 8—Bit 8 of the general-purpose I/O port D. 
LD1i—One of the 12 data bus bits used to drive the LCD panel. 


VDO0—One of the data bus bits of the video controller used for driving the video 
encoder. 









General-Purpose I/O Port D Bit 7—Bit 7 of the general-purpose I/O port D. 
LDO—One of the 12 data bus bits used to drive the LCD panel. 


FIELD—The line the video controller uses to signal which of the two fields is the 
current one. 








General-Purpose I/O Port D Bit 6—Bit 6 of the general-purpose I/O port D. 


LCD_AC—This el ed signal from the LCD controller toggles once every 
programmable number of frames. It is used with passive panels. 


LOE—The output enable signal that is used with TFT panels. 


BLANK—The video controller uses this signal to let the video encoder know that the 
current cycle is a blank type. 













General-Purpose I/O Port D Bit 5—Bit 5 of the general-purpose 1/O port D. 
FRAME—The output signal from the video controller that marks the beginning of a 
new frame. 

VSYNC—The output signal from the LCD controller that marks the beginning of a 
new frame. 











General-Purpose I/O Port D Bit 4—Bit 4 of the general-purpose I/O port D. 
LOAD—The output signal from the video controller that marks the beginning of a 
new display line. 

HSYNC—The output signal from the LCD controller that marks the beginning of a 
new frame. 
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External Signals 


Table 2-1. Signal Descriptions (Continued) 


SIGNAL PIN NUMBER DESCRIPTION 



















PD{3] General-purpose I/O Port D Bit 3—Bit 3 of the general-purpose I/O port D. 
SHIFWOLK SHIFT/CLK—This output signal is used to generate the shift clock timing to the LCD 
CLK panel when using the LCD controller. The direction is defined when you program it. 


CLK—When the video controller is used, the CLK function can either be an output 
clock to drive the video encoder or an external input clock from the video encoder to 
drive the video controller. The direction is defined when you program it. 












Power Supply | See Table 2-2 | VDDL—Power supply of the internal logic. 
for pin VDDH—Power supply of the I/O buffers and certain parts of the clock control. 

breakout. | yopsSyN—Power supply of the phase-locked loop circuitry. 

VSSSYN—Power supply of the phase-locked loop ground. 

VSSSYN1—Power supply of the phase-locked loop ground. 

GND—Power supply ground. 


KAPWR—Power supply of the internal oscillator, real-time clock, periodic interrupt 
timer, decrementer, and timebase. 


TCK T12 Test Clock—This input signal is the clock of the JTAG interface. 

DSCK Development Serial Clock—This input signal is the clock for the debug port 
interface. 

TMS R12 Test Mode Select—This input signal controls the TAP machine sequence in the 
JTAG interface. 

ue a Test Data Input—This input signal is the data in the JTAG interface. 
interface. 
Development Serial Data Output—This ones signal is the data out of the debug 


Development Serial Data Input—This input signal is the data for the debug port 
_{ port interface. 


interface. 
Test Reset—This input signal is the asynchronous reset of the TAP machine on the 
JTAG interface. 


eee lene 2-2 |No Connect—These pins are not connected. 
or pin 
breakout. 


























Test Data Output—This three-state output signal is the data out of the JTAG 
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Table 2-2. Pin Breakout 


SIGNAL PIN NUMBER 


ADDRESS BUS PINS 
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External Signals 


2-14 


Table 2-2. Pin Breakout (Continued) 


SIGNAL PIN NUMBER 
ee 


D1 
D2 J2 










DATA BUS PINS 


0|9 
#& | 


oi 
<= 


i; we) 
oO N 
| SS 


= 
—h, 
x 







fon 
r 
-D15 J4 
—D16 H2 
D17 K 


an cq <= mj mle 


D19 G 
D20 G 
‘D21 F 
D22 H 


D23 
24 


_ 
i 


Oo 


al 
16) 


aN 


25 
D26 
D27 L3 


m 


NO 
(oe) 
a 


m 
NO 


D29 
D30 


O 
Nh 
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Table 2-2. Pin Breakout (Continued) 


SIGNAL PIN NUMBER 









CHIP SELECT PINS 





POWER SUPPLY PINS 


[woos [et 
GND 







F6-Fi1, G6-G11, 
H6-H11, J6—J11, 
K6-K11, L6-L11 


N/C Ai6, C1, C6, E14, 
J13, N9, N13, 
P1, P10 





NO CONNECT PINS 
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SECTION 3 
MEMORY MAP 


This section discusses the internal memory map (including key registers) of the MPC823. 
Each memory resource is mapped within a contiguous block of 16K storage. The location of 
this block within the global 4G real storage space can be mapped on 64K resolution through 
an implementation specific special register called the internal memory map register (IMMR). 
Refer to Section 12.12.1.2 Internal Memory Map Register for more information. 


Note: If you are using Mask Revision Base # F988, there are only two timers. 





Table 3-1. MPC823 Internal Memory Map 


ADDRESS REGISTER (IN BITS) LOCATION 
f_emo—[SUNCR-SWMoiecontgatonsensur | ge | 200 
[oot [vor Syetentctn concrregr |e 
[eieioo0o [rested SP 
[me [swehsotvareSeniwregss YT 
[—e16—[srENO—SU erupt Perdng ensure |e 







SRO BU newer |e 

sso ene eeltegaw |e 
6 Javea nenetiesrrogae 
ec 
eo laa teenes 
SDCR—SDMA Configuration Register 
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Memory Map 





Table 3-1. MPC823 Internal Memory Map (Continued) 


INTERNAL SIZE PAGE NUMBER 
ADDRESS REGISTER (IN BITS) LOCATION 








PBRO—PCMCIA Interface Base Register 0 

PORO—PCMCIA Interface Option Register 0 
PBR1—PCMCIA Interface Base Register 1 17-16 
POR1—PCMCIA Interface Option Register 1 17-17 
PBR2—PCMCIA Interface Base Register 2 17-16 


POR2—PCMCIA Interface Option Register 2 


| 0B PBR3—PCMCIA Interface Base Register 3 


17-17 
17-16 


POR38—PCMCIA Interface Option Register 3 17-17 


PBR4—PCMCIA Interface Base Register 4 17-16 


POR4—PCMCIA Interface Option Register 4 17-17 


PBR5—PCMCIA Interface Base Register 5 17-16 


POR5—PCMCIA Interface Option Register 5 17-17 


| OBO PBR6—PCMCIA Interface Base Register 6 


17-16 


POR6—PCMCIA Interface Option Register 6 17-17 





PBR7—PCMCIA Interface Base Register 7 17-16 


a, | oh 
“NJ ON 
= | = 
N | Oo 





POR7—PCMCIA Interface Option Register 7 17-17 


0COto0E3 | RES—Reserved p= | 





PGCRB—PCMCIA Interface General Control Register B 17-15 





PSCR—PCMCIA Interface Status Change Register 17-11 





080 
084 
088 
08C 
094 
098 
09C 
OAO 
OA4 
OA8 
OAC 
OBO 
OBA 
OB8 
OBC 
Soa 
0&4 ms 
mn 
OECtoOEF | RES—Reserved eS ee 
OFO PIPR—PCMCIA Interface Input Pins Register 
Le 
3 
i oe 





oF4100F7 | RES Reserved ar 


PER—PCMCIA Interface Enable Register 


OFC toOFF | RES—Reserved po | 


LE EEE LE ne 


BRO—Base Register Bank 0 


17-13 

















ORO—Option Register Bank 0 
BRi—Base Register Bank 1 
OR1—Option Register Bank 1 
BR2—Base Register Bank 2 
OR2—Option Register Bank 2 


ne 
ne) 
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Table 3-1. MPC823 Internal Memory Map (Continued) 


aes [ere [PR 
ADDRESS REGISTER (IN BITS) LOCATION 
BR4—Base Register Bank 4 32 15-9 
OR4—Option Register Bank 4 
BR5—Base Register Bank 5 

12C OR5—Option Register Bank 5 
BR6—Base Register Bank 6 
OR6—Option Register Bank 6 
BR7—Base Register Bank 7 
OR7—Option Register Bank 7 
RES—Reserved 
MAR—Memory Address Register 
MCR—Memory Command Register 
RES—Reserved 
MAMR—Machine A Mode Register 
MBMR—Machine B Mode Register 
MSTAT—Memory Status Register 
MPTPR—Memory Periodic Timer Prescaler 
MDR—Memory Data Register 
RES—Reserved 


ie) 
Nh 


15-11 


io) 
N 


15-9 


ié) 
N 


15-11 


(oe) 
Nh 


= | o (se) 
Oo | Om Nh 


15-9 


ie) 
ine) 


15-11 


ioe) 
NO 


15-9 


ee) 
N 


15-11 


15-27 


ee) 
N 


15-17 


ie) 
NO 


15-19 


oe) 
NM 


15-23 
15-15 
15-28 


OG 
NO 


= 





TBSCR—Timebase Status and Control Register 


204 TBREFU—Timebase Reference Register Upper 


TBREFL—Timebase Reference Register Lower 
RES—Reserved 

RTCSC—Real-Time Clock Status and Control Register 

RTC—Real-Time Clock Register 


RTSEC—Real-Time Clock Alarm Seconds Register 


RTCAL—Real-Time Clock Alarm Register 32 


230 to 23F RES—Reserved Po | 
PISCR—Periodic Interrupt Status and Control Register | te | te 
PITC—Periodic Interrupt Timer Count Register 12-24 


ao;}a;— ao;Q;! — 
mM] mM] oO hm} MO] © 
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Table 3-1. MPC823 Internal Memory Map (Continued) 


INTERNAL SIZE PAGE NUMBER 

ADDRESS REGISTER (IN BITS) LOCATION 

PITR—Periodic Interrupt Timer Register 
24C to 27F RES—Reserved se 


ntrol Register 













284 
288 





5 


5-27 


330 to 33F 


348 to 37F 


5-27 
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VCCR—Video Controller Configuration Register 


802 to 803 RES—Reserved 


804 VSR—Video Status Register 19-7 





805 RES—Reserved 


Seay 
= 
oN 
SS 
ERS < 
Se 
REE 
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Table 3-1. MPC823 Internal Memory Map (Continued) 
INTERNAL PAGE NUMBER 


SIZE 
ADDRESS REGISTER (IN BITS) LOCATION 


[ee __ [Vena tonal conmenaneaser ff 
[wor reste 
ister ( 
3 






















— 
O) 


VFBA1—Video Frame Buffer B Start Address Register (Set 1) 32 


828 to 83F RES—Reserved 


820 
824 








ss 
oe Bee 





LCHCR—LCD Horizontal Control Register 


840 i 
844 
50 
54 
58 


LCCR—LCD Panel Configuration Register 


859 to 85F RES—Reserved - 


32 
32 
32 
32 
32 


8 
8 


8 







ee 


fe 
: 


870 I2CER—I°C Event Register 


I2CMR—I*C Mask Register | 
875 to 8FF RES—Reserved | 








860 
864 
868 

6C 


8 







_ 
? 
a 
ao 
= 





MOTOROLA MPC823 USER’S MANUAL 3-5 





a 

. 
= 
> 
cc : 
.@) 
= 
wi 

= 





= 
m 
= 
2) 
a 
< 
= 
> 
me) 





Memory Map 





Table 3-1. MPC823 Internal Memory Map (Continued) 


INTERNAL 


SIZE 
ADDRESS REGISTER (IN BITS) 


900 to 903 RES—Reserved 


SDAR—SDMA Address Register 


PAGE NUMBER 
LOCATION 








SDSR—SDMA Status Register (DSP Interrupts) 


909 to 90B RES—Reserved 


SDMR—SDMA Mask Register (DSP Interrupts) 


90D to 90F | RES—Reserved 


IDSR—IDMA1 Status Register 


911t0913 | RES—Reserved po | 





16-88 
16-36, 16-89 








914 IDMR—IDMA1 Mask Register 


915 to 917 RES—Reserved 


IDSR—IDMA2 Status Register 


919 to 91B RES—Reserved 


IDMR—IDMA2 Mask Register 














sedatcaernneanittdN rate se 


91D to 92F RES—Reserved 

















en: 





wae 
IROCE SSOP 
PN SOE ENS 
Soe 





PADIR—Port A Data Direction Register 
PAPAR—Port A Pin Assignment Register 
PAODR—Port A Open-Drain Register 
PADAT—Port A Data Register 


958 to 95F RES—Reserved 


PCDIR—Port C Data Direction Register 







PCPAR—Port C Pin Assignment Register 
PCSO—Port C Special Options Register 


3-6 


MPC8&23 USER’S MANUAL MOTOROLA 


Memory Map 


Table 3-1. MPC823 Internal Memory Map (Continued) 





















INTERNAL SIZE PAGE NUMBER 
ADDRESS REGISTER (IN BITS) LOCATION 
| ) 966 PCDAT—Port C Data Register 
| 968 PCINT—Port C Interrupt Control Register 
PDDIR—Port D Data Direction Register 


RES—Reserved 


16-487 
16 16-486 


PDDAT—Port D Data Register 


978 to 97F RES—Reserved 


968 
PDPAR—Port D Pin Assignment Register 






oh 


p80 TGCR—Timer Global Configuration Register 
982 to 98F RES—Reserved 


TMR1—Timer1 Mode Register 


Sy 


— {| Pa es ee es Cs CO ree See eC ee Ge ea ee i Ges Co es Ce — | a — | om 
Oo | © D1 DI] DIL Oi DI ai nt Ds] aI Om Oo; on! ms! @I| Oo oO | ® Oo} © 


16-79 


16-80 


16 


TMR2—Timer2 Mode Register 16-80 


16-80 


TMR38—Timer3 Mode Register 





| 16-80 
TRR2—Timer2 Reference Register 16-81 


Ss 
S 
Ss 


TRR3—Timer3 Reference Register 


TRR4—Timer4 Reference Register 


16-81 


16-82 
16-82 
— 16-82 


980 
992 
9A0 
9A2 TMR4—Timer4 Mode Register 
994 
9A4 
9A6 
* 998 


TRRi—Timer1 Reference Register 


TCR1i—Timer1 Capture Register 
TCR2—Timer2 Capture Register 
TCR38—Timer3 Capture Register 


TCR4—Timer4 Capture Register 


TCNi—Timer1 Counter Register 
9B0 
9B2 


TCN2—Timer2 Counter Register 
TCN3—Timer3 Counter Register | 
TCN4—Timer4 Counter Register 
RES—Reserved 


9AO to 9AF 


TER1—Timer1 Event Register 


TER2—Timer2 Event Register 
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Table 3-1. MPC823 Internal Memory Map (Continued) 


‘| > INTERNAL | | SIZE PAGE NUMBER 
_ ADDRESS > . REGISTER (IN BITS) LOCATION 


[200 [CPoRconmunesion PocesorioaueConmansRepser| 16 | 10 
ecawecs [restos 
[204 [RCRAGC nate CaviuaionRepir |e 
On 


a ae 2 
[6 rte fap 
20m [RTA ASCTineriesk fogs 
[wocweer [res feces 


9FO BRGCi—BRG1 Configuration Register 

















ie) 
N 


QF4 


a; @®| @ 
NM | My] M 


BRGC2—BRG2 Configuration Register 


OFS BRGC3—BRGS8 Configuration Register 





9FC BRGC4—BRG4 Configuration Register 





A0O USMOD—USB Mode Register 


SBOP RRA DI SUDO OPA OTOP TODO D IER ONE GLE IR ERO EI PEDDLE EAE EEE E EERE RT ENDED TED ETEE EEE ERE OEE ONSEN AES TES 


16-357 
AO1 USADR—USB Slave Address Register 
Ad2 


USCOM—USB Command Register 
AO3 RES—Reserved 
- Ad4 USEPO—USB End Point 0 Register 


o>) 


A06 USEP1—USB End Point 1 Register 


A08 
AOA 


USEP2—USB End Point 2 Register 
USEP3—USB End Point 3 Register 
AOC to AOF RES—Reserved 


A10 USBER—USB Event Register 


oO) 


os | — | — 
oO) 


16-368 


A12 RES—Reserved 


Oo 


A14 USBMR—USB Mask Register 


A16 RES—Reserved 


S 
co 
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Table 3-1. MPC823 Internal Memory Map (Continued) 


INTERNAL 

ADDRESS REGISTER 
A17 USBS—USB Status Register 

A18 to A1F RES—Reserved 


















SIZE 
(IN BITS) 


PAGE NUMBER 
LOCATION 









34 ee 





z Jos 


as 


Es 3 ; ge 
A20 GSMR_L—SCC2 General Mode Low Register 32 
A24 GSMR_H—SCC2 General Mode High Register 32 


A28 SCC2 PSMR—Protocol-Specific Mode Register 





a 
: 



















16-211 (UART 
16-236 (HDLC 
16-272 (AHDL 

16-302 (Trans) 





A2A to A2B RES—Reserved 
A2C TODR—Transmit-on-Demand Register 
A2E DSR—Data Synchronization Register 


A30 SCCE—SCC2 Event Register 


16-181 
16-221 (UART 
16-243 (HDLC 
16-277 (AHDLC) 
16-307 (Trans) 





A32 RES—Reserved 


A34 SCCM—SCC2 Mask Register 


A386 RES—Reserved 


A37 SCCS—SCC2 Status Register 


A38 IRMODE—SCC2 Infra-Red Mode Register 


A3A IRSIP—SCC2 Infra-Red Serial Interaction Pulse Control 
Register 


RES—Reserved 


SMCMR—SMC Mode Register 















A3C to A81 


(op) o> oO Oo o) oOo oO Oo) ©) 










A82 


A84 RES—Reserved 


A86 SMCE—SMC Event Register 


RES—Reserved 


oO 


16-374 
16-388 (UART 
16-406 (Trans 

16-421 (GCI) 





A87 to A89 


a —_ 
(o>) 
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Table 3-1. MPC823 Internal Memory Map (Continued) 
INTERNAL | SIZE PAGE NUMBER 
ADDRESS REGISTER. (IN BITS) LOCATION 
A8A _—_—«| SMCM—SMC Mask Register | | 16-397 (UART 
| 16-413 (Trans) 
16-423 (GCI) 


A8B to A91 RES—Reserved 


SMCE—SMC Event Register 


9 
9 SMCM—SMC Mask Register | | pe * 6-397 (UART 
. 6-413 (Trans) 
6-423 (GCl) 


A97 to A99 RES—Reserved 


A9B to A9OF RES—Reserved 


Secs Sand ano neprn sie 
c ee foe 


Za I aa ee TT eae 
. 16-374 

16-388 (UART 

16-406 (Trans 

| 16-421 (GCI) 


A92 
AQA 


9 


ee eee ee SS 


SPMODE-—SPI Mode Register 


A 
A 
A 


AAO 
AA2 
AAG SPIE—SPI Event Register 
AAA 


SPIM—SPI Mask Register 


AAE to AB1 


oy 


AA7 to AAQ9 RES—Reserved 


dVW AYOWSN 


PBPAR—Port B Pin Assignment Register 
PBODR—Port B Open-Drain Register 
PBDAT—Port B Data Register 
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Table 3-1. MPC823 Internal Memory Map (Continued) 


INTERNAL SIZE PAGE NUMBER 
ADDRESS REGISTER (IN BITS) LOCATION 


SIMODE—Serial Interface Mode Register 
SIGMR—Serial Interface Global Mode Register 
RES—Reserved 

SISTR—Serial Interface Status Register 
SICMR—Serial Interface Command Register 
RES—Reserved 

SlCR—Serial Interface Clock Route Register 
SIRP—Serial Interface RAM Pointer Register 


ms 


L ee : : 
VCRAM—Video Controller RAM Array 256 bytes 
SIRAM—Serial Interface RAM 512 bytes 


LCOLR—LCD Color RAM 512 bytes 


DPRAM—Dual-Port RAM 4,096 bytes 
DPRAM—Dual-Port RAM Expansion po 
3C00 to 3FFF | PRAM—Parameter RAM 1,024 bytes 


MEMORY MAP 
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SECTION 4 
RESET 


The reset block of the MPC823 has a reset control logic that determines the cause of reset, 
synchronizes it if necessary, and resets the appropriate logic modules. The memory 
controller, system protection logic, interrupt controller, and parallel I/O pins are initialized 
only on hard reset. Soft reset initializes the internal logic while maintaining the system 
configuration. 


RESET 
SOURCE 


eS Oe Fe ae ee Oe Sa a 


External Hard Reset 
Loss-of-Lock 
Software Watchdog 
Check Stop 
Debug Port Hard Reset 
JTAG Reset 
External Soft Reset 
Debug Port Soft Reset 


NOTE: \ indicates that the logic circuitry is reset or the appropriate pin is driven by the source. 
— indicates that the logic circuitry is not affected. 


Table 4-1. Possible Reset Results 


RESET EFFECT 


SYSTEM HRESET | DEBUG OTHER SRESET 
CONFIG | MODULE PIN PORT INTERNAL PIN 

RESET DRIVEN | CONFIG LOGIC DRIVEN 
RESET |. 
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4.1 TYPES OF RESET 
The MPC823 has several types of inputs to the reset logic: 


e Power-on reset 
e External hard reset 
e Internal hard reset 


Li Loss of lock 

1} Software watchdog reset 
Li Checkstop reset 

[1 Debug port hard reset 

Li JTAG reset 


e External soft reset 
e Internal soft reset 


1 Debug port soft reset 
Li JTAG soft reset 


_ All of these reset sources are fed into the reset controller and, depending on the source of 
the reset, different actions are taken. The reset status register reflects the last source to 
cause a reset. | 


4.1.1 Power-On Reset 


PORESET (power-on reset) is an active low input pin. In a system with power-down 
low-power mode, this pin should only be activated when a voltage in the keep-alive power 
(KAPWR) rail fails. When this pin is asserted, the MODCK bits are sampled and the 
phase-locked loop multiplication factor and pitrtclk and tmbclk sources are changed to their 
default values. When this pin is negated, internal MODCK values are unchanged. The 
PORESET pin should be asserted for a minimum of 3 microseconds. After detecting this 
assertion, the MPC823 enters the power-on reset state and stays there until the following 
events occur: | 7 7 


e The internal PLL enters the lock state and the system clock is active 
e The PORESET pin is negated 


When PORESET is asserted, the MPC823 enters the power-on reset (POR) state in which 
SRESET and HRESET are asserted by the core. When the MPC823 remains in POR, the 
extension counter of 512 is reset, and the MODCK pins are sampled when POR pin is 
negated. After the negation of PORESET or PLL lock, the core enters the state of internal 
initiated HRESET and continues driving the HRESET and SRESET pins for 512 cycles. 
When the timer expires, which is usually after the 512 cycles, the configuration is sampled 
from the data pins and the core stops driving the pins. An external pull-up resistor should 
drive the HRESET and SRESET pins high. After the pins are negated, a 16-cycle period 
passes before the presence of an external (hard/soft) reset is tested. Refer to 

Section 4.3.1 Hard Reset for more information. 
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4.1.2 External Hard Reset 


HRESET (hard reset) is a bidirectional, active low I/O pin. The MPC823 can only detect an 
external assertion of HRESET if it occurs while the MPC823 is not asserting reset. During 
HRESET, SRESET is asserted. HRESET is an open-collector type of pin. SRESET (soft 
reset) is a bidirectional, active low I/O pin. The MPC823 can only detect an external 
assertion of SRESET if it occurs while the MPC823 is not asserting reset. The SRESET is 
also an open-collector type of pin. 


When an external HRESET is asserted, the core starts driving the HRESET and SRESET 
for 512 cycles. When the timer expires, after 512 cycles, the configuration is sampled from 
the data pins and the core stops driving the HRESET and SRESET pins. An external pull-up 
resistor should drive the pins high and once they are negated, a 16-cycle period passes 
before the presence of an external (hard/soft) reset is tested. Refer to Section 4.3.1 Hard 
Reset for more information. 


4.1.3 Internal Hard Reset 


When the core finds a reason to assert HRESET, it starts driving the HRESET and SRESET 
pins for 512 cycles. When the timer expires, after the 512 cycles, the configuration is 
sampled from data pins and the core stops driving the pins. An external pull-up resistor 
should drive the HRESET and SRESET pins high and once they are negated a 16-cycle 
period passes before the presence of an external (hard/soft) reset is tested. Refer to 
Section 4.3.1 Hard Reset for more information. The causes of internal hard reset are as 
follows: 


e Loss of lock 

e Software watchdog reset 
e Checkstop reset 

e Debug port hard reset 

° JTAG reset 


4.1.3.1 LOSS OF LOCK. Ifthe PLL detects a loss of lock, erroneous external bus operation 
occurs if synchronous external devices use the core input clock. Erroneous operation could 
also occur if devices with a PLL use the core clockout. This source of reset can be asserted 
if the LOLRE bit in the PLL low-power and reset control register is set. The enabled PLL 
loss-of-lock event generates an internal hard reset sequence. 


4.1.3.2 SOFTWARE WATCHDOG RESET. After the core watchdog counts to zero, a 
software watchdog reset is asserted. The enabled software watchdog event then generates 
an internal hard reset sequence. 


4.1.3.3 CHECKSTOP RESET. If the core enters a checkstop state and the checkstop reset 
is enabled, the checkstop reset is asserted. The enabled checkstop event then generates 
an internal hard reset sequence. 
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4.1.3.4 DEBUG PORT HARD RESET. When the development port receives a hard reset 
request from the development tool, an internal hard reset sequence is generated. In this 
case, the development tool must reconfigure the debug port. See 

Section 20.2.1.2.6 Detecting the Trace Window End Address for more information. - 


4.1.3.5 JTAG RESET. When the JTAG logic asserts the JTAG soft reset signal, an internal 
soft reset sequence will be generated. 


4.1.4 External Soft Reset 


When an external SRESET is asserted, the core starts driving the SRESET pin. When the 
timer expires, after 512 cycles, the debug port configuration is sampled from the DSDI and 
DSCK pins and the core stops driving the pin. An external pull-up resistor should drive it high 
and once it is negated a 16-cycle period passes before the presence of an external soft reset 
is tested. 


4.1.5 Internal Soft Reset 


When the core finds a reason to assert SRESET, it starts driving the SRESET pin. When 
the timer expires, after 512 cycles, the debug port configuration is sampled from the DSDI 
and DSCK pins and the core stops driving the SRESET pin. An external pull-up resistor 
should drive the pin high and once it is negated a 16-cycle period passes before the 
presence of an external soft reset is tested. JTAG and the debug port cause an internal soft 
reset. 


4.1.5.1 DEBUG PORT SOFT RESET. When the development port receives a soft reset 
request from the development tool, an internal soft reset sequence is generated. In this case 
the development tool must reconfigure the debug port. See Section 20.2.1.2.6 Detecting 
the Trace Window End Address for more information. 
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4.2 RESET STATUS REGISTER 


The 32-bit reset status register (RSR) is powered by the keep-alive power supply. As shown 
in Section 3 Memory Map, it is memory-mapped into the MPC823 system interface unit 
register map and receives its default reset values at power-on reset. 


RSR 











EHRS | ESRS | LLRS | SWRS | CSRS | DBHRS | DBSRS |} JTRS RESERVED 


. RESERVED 










EHRS—Externa! Hard Reset Status 


This bit is cleared by a power-on reset. When an external hard reset event is detected, this 
bit is set and remains that way until the software clears it. The EHRS bit can be negated by 
writing a 1, but a write of zero has no effect on it. 


0O= No external hard reset event occurred. 
= An external hard reset event occurred. 


ESRS—External Soft Reset Status 


This bit is cleared by a power-on reset. When an external soft reset event is detected, this 
bit is set and remains that way until the software clears it. The ESRS bit can be negated by 
writing a 1, but a write of zero has no effect on it. 


O= No external soft reset event occurred. 
1 = An external soft reset event occurred. 


LLRS—Loss-of-Lock Reset Status 


This bit is cleared by a power-on reset. When a loss-of-lock event is enabled by the LOLRE 
bit in the PLPRCR is detected, this bit is set and remains that way until the software clears 
it. The LLRS bit can be negated by writing a 1, but a write of zero has no effect on it. 


O= No enabled loss-of-lock reset event occurred. 
1 = An enabled loss-of-lock reset event occurred. 
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SWRS—Software Watchdog Reset Status 


This bit is cleared by a power-on reset. When a software watchdog expire event occurs, this 
bit is set and remains that way until the software clears it. The SWRS bit can be negated by 
writing a 1, but a write of zero has no effect on it. 


O = No software watchdog reset event occurred. 
1 = A software watchdog reset event occurred. 


CSRS—Check Stop Reset Status 


This bit is cleared by a power-on reset. When the core enters the checkstop state and the 
checkstop reset is enabled by the CSR bit in the PLPRCR, this bit is set and remains that 
way until the software clears it. The CSRS bit can be negated by writing a 1, but a write of 
zero has no effect on it. 


0 = No enabled checkstop reset event occurred. 
1 = An enabled checkstop reset event occurred. 


DBHRS—Debug Port Hard Reset Status 


This bit is cleared by a power-on reset. When the debug port hard reset request is set, this 
bit is set and remains that way until the software clears it. The DBHRS bit can be negated 
by writing a 1, but a write of zero has no effect on it. 


O = No debug port hard reset request occurred. 
1 = A debug port hard reset request occurred. 


DBSRS—Debug Port Soft Reset Status 


This bit is cleared by a power-on reset. When the debug port soft reset request is set, this 
bit is set and remains that way until the software clears it. The DBSRS bit can be negated 
by writing a 1, but a write of zero has no effect on it. 


0 = No debug port soft reset request occurred. 
1 = A debug port soft reset request occurred. 


JTRS—JTAG Reset Status 


This bit is cleared by a power-on reset. When the JTAG reset request is set, this bit is set 
and remains that way until the software clears it. The JTRS bit can be negated by writing a 
1, but a write of zero has no effect on it. 


-0= NoJTAG reset event occurred. 
1= AJTAG reset event occurred. 


Bits 8-31—Reserved 
These bits are reserved and should be set to 0. 
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4.3 HOW TO CONFIGURE RESET 


In normal operation, you can configure reset with a hard reset. However, to configure the 
development port you should use a soft reset. 


4.3.1 Hard Reset 


When a hard reset event occurs, the MPC823 reconfigures its hardware system as well as 
the development port configuration. The logical value of the bits that determine its initial 
mode of operation are sampled either from the data bus or from an internal default constant 
(D[0:31]=x’00000000). If, at sampling time, RSTCONF is asserted, the configuration is 
sampled from the data bus. Otherwise, it is sampled from the internal default. While 
HRESET and RSTCONF are asserted, the MPC823 pulls the data bus low through a weak 
resistor. You can overwrite this default by driving high to the appropriate bit, as shown in 
Figure 4-1. Figures 4-2 through 4-4 illustrate how reset configuration works when PORESET 
is asserted. While the PORESET input signal is being asserted, the core assumes the 
default reset configuration that changes when PORESET is negated or the CLKOUT signal 
starts oscillating. In this last case, the hardware configuration is sampled every nine clock 
cycles on the rising edge of the CLKOUT. The setup time required for the data bus is 15 
cycles and the maximum rise time of HRESET should be less than six clock cycles. For 
more information, see Section 4.3.2 Soft Reset. 


CONFIGURATION _ 


WORD : \/ 





DX (DATA LINE) 





< 





RSTCONF 


MPC823 


Figure 4-1. Reset Configuration Basic Scheme 
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CLKOUT 





PORESET 
INTPORESET 


HRESET 





-RSTCONF 


D[0:31] 


CLKOUT 


PORESET 


INTPORESET 





HRESET 


RSTCONF 


D[0:31] 


TSUP 


LC 
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Figure 4-2. Reset Configuration Sampling Scheme 
For Short PORESET Assertion 
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RSTCONF CONTROLLED 


Figure 4-3. Reset Configuration Sampling Scheme 
For Long PORESET Assertion 
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DATA | | RESET CONFIGURATION WORD | 


| 
| 
| MAXIMUM SETUP TIME OF RESET RECOGNITION | 
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RSTCONF 





SAMPLE . SAMPLE SAMPLE 
DATA DATA DATA 
CONFIGURATION CONFIGURATION CONFIGURATION 


Figure 4-4. Reset Configuration Sampling Timing Requirements 
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Reset 


4.3.1.1 HARD RESET CONFIGURATION WORD. The hard reset configuration word is | 
sampled from the data bus. At reset, the bits will determine the default values of the 
corresponding bits in the SIUMCR, IMMR, and MSR. 


HARD RESET CONFIGURATION WORD 





NOTE: The default value is due to the internal pull-down resistor on the data bus. 


EARB—External Arbitration 


lf this bit is set (1), external arbitration is assumed. If it is cleared (0), then internal arbitration 
is performed. See Section 12 System Interface Unit for more information. 


{tP—tnitial Interrupt Prefix 


This bit defines the initial value of the MSRip immediately after reset. The MSRip bit defines 
the interrupt table location. If IIP is zero (default), the MSR)p initial value is one, but if it is 
sampled one, the MSRip initial value is zero. | 


Bits 2,6, and 15—Reserved | 
These bits are reserved and should be left open. 


BDIS—Boot Disable 


O= The memory controller is activated after reset so that it matches all addresses. 
1 = The memory controller is not activated after reset, but it is cleared. 


BPS—Boot Port Size 
This field defines the port size of the boot device. 


00 = 32-bit port size. 
01 = 8-bit port size. 
10 = 16-bit port size. 
11 = Reserved. 


[SB—lnitial Internal Space Base Select 


This field defines the initial value of the IMMR bits 0-15 and determines the base address of 
the internal memory space. 


00 = 0x00000000. 
01 = Ox00F00000. 
10 = OxFFO00000. 
11 = OxFFFO0000. 


4-10 MPC823 USER’S MANUAL MOTOROLA 


Reset 


DBGC—Debug Pins Configuration 7 
This field configures the functionality of the following pins. 


Ox= IWP[0:1]/VFLS[0:1] functions as IWP[0:1]. 
IWP2/VF2 functions as IWP2. 
LWPO/VFO functions as LWPO. 
LWP1/VF1 functions as LWP1. 
MODCK1/STS functions as STS. 
DSCK/AT1 functions as AT1. 
DSDI/IRQ5 functions as IRQ5. 
PTR/ATS functions as AT3. 
MODCK2/DSDO functions as DSDO. 
10= Reserved. 
11= IWP[0:1]/VFLS[0:1] functions as VFLS[0:1]. 
IWP2/VF2 functions as VF2. 
LWPO/VFO functions as VFO. 
LWP1/VF1 functions as VF1. 
MODCK1/STS functions as STS. 
DSCK/AT1 functions as AT1. 
DSDI/IRQ5 functions as IRQ5. 
PTR/ATS functions as AT3. 
MODCK2/DSDO functions as DSDO. 


DBPC—Debug Port Pins Configuration 
This field configures the following pins on the active development port. 


00= DSCK/AT1 functions as defined by DBGC. 
DSDI/IRQ5 functions as defined by DBGC. 
PTR/ATS functions as defined by DBGC. 
TCK/DSCK functions as DSCK. 
TDI/DSDI functions as DSDI. 
TDO/DSDO functions as DSDO. 

01= DSCK/ATS functions as defined by DBGC. 
DSDI/IRQ5 functions as defined by DBGC. 
PTR/ATS functions as defined by DBGC. 
TCK/DSCK functions as TCK. 
TDI/DSDI functions as TDI. | 
TDO/DSDO functions as TDO. 

10= Reserved. , 

11= DSCK/AT1 functions as DSCK. 
DSDI/IRQ5 functions as DSDI. 
PTR/ATS functions as PTR. 
TCK/DSCK functions as TCK. 
TDI/DSDI functions as TDI. 
TDO/DSDO functions as TDO. 
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EBDF—External Bus Division Factor 


These bits define the frequency division factor between GCLK1/GCLK2 and 
GCLK1_50/GCLK2_50. CLKOUT is similar to GCLK2_50. GCLK2_50 and GCLK1 50 are 
used by the system interface unit and memory controller to interface with the external 
system. The EBDF bits are initialized during HRESET using the hard reset configuration 
mechanism. 


4.3.2 Soft Reset 
When a soft reset event occurs, the MPC823 reconfigures the development port. 
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SECTION 5 
CLOCKS AND POWER CONTROL 


The MPC823 clock system provides many different timing options for all on-chip and 
external devices. It contains phase-locked loop circuitry and frequency dividers that 
generate programmable clock timing for baud rate generators, timers, the LCD controller, 
and a variety of low-power mode options. 


The programmable phase-locked loop, called the system phase-locked loop (SPLL) in the 
MPC823, generates the overall system operating frequency. You can program the SPLL in 
integer multiples of the input clock frequency. The minimum internal operating frequency is 
15MHz. To generate the system operating frequencies, divide by a power of two divider. The 
clock sources to the timebase, decrementer, real-time counter, and periodic interrupt 
counter are generated by the MPC823 clock module. For additional timer information, refer 
to Section 12 System Interface Unit. 


The MPC823 has a variety of programmable modes that allow your system to operate at its 
highest level, and yet it still gives you the option of operating in a power-saving mode. 
Figure 5-1 illustrates the internal clock source and distribution that includes the SPLL, clock 
dividers, drivers, and main clock oscillator. 


5.1 FEATURES 


~ The following list summarizes the main features of the MPC823 clocks and power control 
system: 

° Contains System Phase-Locked Loop (SPLL) 

e Clock Dividers Are Provided for Low-Power Modes and Internal Clocks 

e Contains Five Major Power-Saving Modes: 


1 Normal, Doze, Sleep, Deep Sleep, and Power-Down. Normal and Doze have both 
high and low modes of operation. 


e Able to Operate the Core at Low Voltage for Various Power-Saving Modes 
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TBS (SCCR) GCLK1_50/GCLK2_50 
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= — CLOCK 
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——————_—_—_—-—_ 
SYNCCLK 
ge 
28 
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DRIVER 





AND DRIVER 






MAIN CLOCK 
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| 
| 
| 
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| 
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| 
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| 
| 
| 
| 
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| 
| 
| 
| 
| 
BRGCLK : 
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| 
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| 
| 
| 
| 
| 
| 
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| 
| 
| 
OSCILLATOR (OSCM) | 


Figure 5-1. Clock Source and Distribution 
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5.2 REGISTER MODEL 
5.2.1 System Clock and Reset Control Register 


The SPLL has a 32-bit control register that is powered by keep-alive power. The system 
clock and reset control register (SCCR) is memory-mapped into the MPC823 system 
interface unit’s register map. 


SCCR 


RESERVED TBS j{ RTDIV | RTSEL | CRQEN | PRQEN RESERVED 
Seo 


(IMMR & OxFFFFO000) + 0x280 


1 
te 
ae AE 2 eS 
DFSYNC DFBRG DFNL DFNH DFLCD DFALCD 


a a ee ee 
(IMMR & OxFFFFO000) + 0x282 


NOTE: HRESET is hard reset and POR is power-on reset. 
— = undefined and # = unaffected. 
* RTDIV depends on the combination of MODCK1and MODCK2. RTSEL depends on MODCK1. 
See Table 5-2 for more information. 
tT This field is set according to the default of the hard reset sontiguration word. 


anna 





Bits 0 and 83-5—Reserved | 
These bits are reserved and should be set to 0. 


COM—Clock Output Module 


This field controls the output buffer strength of the CLKOUT pin. When both bits are set, the 
CLKOUT pin is held in the high state. These bits can be dynamically changed without 
generating spikes on the CLKOUT pin. If the CLKOUT pin is not connected to external 
circuits, both bits are should be set to minimize noise and power dissipation. The COM field 
is cleared by hard reset. 


00 = Clock output enabled full-strength buffer. 
= Clock output enabled half-strength output buffer. 
10 = Reserved. | 
= Clock output disabled. 
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TBS—Timebase Source | 
This bit determines the clock source that drives the timebase and decrementer. 


0 = Timebase frequency source is OSCCLK divided by 4 or 16. 
1 = Timebase frequency source is GCLK2 divided by 16. 


RTDIV—Real-Time Clock Divide 


This bit indicates if the clock, the crystal oscillator or main clock oscillator, to the real-time 
clock and periodic interrupt timer is divided by 4 or 512. At power-on reset this bit is cleared 
if the MODCK1 and MODCk2 signals are low. | 


O= The clock is divided by 4. 
1 = The clock is divided by 512. 


RTSEL—Real-Time Clock Select 


This bit selects the crystal oscillator or main clock oscillator as the input source to the 
real-time clock. At power-on reset, this bit reflects the value of the MODCK1 signal. 


O= The main clock oscillator is selected. 
1 = The crystal oscillator is selected. 


CRQEN—CPM Request Enable 


This bit is cleared by power-on or hard reset and specifies if the general system clock returns 
to the high frequency while the communication processor module’s RISC microcontroller is 
active. 


0 = The system remains in the lower frequency even if the communication processor 
module is active. | 

1 = The system switches to high frequency when the communication processor 
module is active. 


PRQEN—Power Management Request Enable 


This bit specifies whether or not the general system clock returns to a high frequency when 
a pending interrupt from the interrupt controller or POW bit in the machine state register is 
clear (normal mode). This bit is cleared by power-on or hard reset. 


0= The system remains in low frequency even if there is a pending interrupt from the 
_ interrupt controller or power management bit in the machine state register is 
cleared (normal mode). 
1 = The system switches to high frequency when there is a pending interrupt from the 
interrupt controller or power management bit in the machine state register is 
cleared. 


Bits 11-12 and 15—16—Reserved 
These bits are reserved and should be set to 0. 
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EBDF—External Bus Division Factor 


This field defines the frequency division factor between GCLKx and GCLKx_50. CLKOUT 
is similar to GCLK2_50. The GCLKx_50 is used by the bus interface and memory controller 
to interface with an external system. This field is initialized during hard reset using the hard 
reset configuration word in Section 4.3.1.1 Hard Reset Configuration Word. 


00 = CLKOUT is GCLK2 divided by 1. 
01 = CLKOUT is GCLK2 divided by 2. 
1x = Reserved. 


DFSYNC—Division Factor for the SYNCCLK 


This field sets the VCOOUT frequency division factor for the SYNCCLK signal. Changing 
the value of this field does not result in a loss-of-lock condition. This field is cleared by a 
power-on or hard reset. 


00 = Divide by 1 (normal operation). 
O01 = Divide by 4. 

10 = Divide by 16. 

11 = Divide by 64. 


DFBRG—Division Factor of the BRGCLK 


This field sets the VCOOUT frequency division factor for the BRGCLK signal. Changing the 
value of this field does not result in a loss-of-lock condition. This field is cleared by a 
power-on or hard reset. 


00 = Divide by 1 (normal operation). 
01 = Divide by 4. 

10 = Divide by 16. 

11 = Divide by 64. 


DFNL—Division Factor Low Frequency 


This field sets the VCOOUT frequency division factor for general system clocks to be used 
in low-power mode. In low-power mode, the MPC823 automatically switches to the DFNL 
frequency. To select the DFNL frequency, load this field with the divide value and set the 
CSRC bit. A loss-of-lock condition will not occur when you change the value of this field. This 
field is cleared by a power-on or hard reset. 


000 = Divide by 2. 
001 = Divide by 4. 
010 = Divide by 8. 
011 = Divide by 16. 
100 = Divide by 32. 
101 = Divide by 64. 
110 = Reserved. 
111 = Divide by 256. 
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DFNH—Division Factor High Frequency 


This field sets the VCOOUT frequency division factor for general system clocks to be used 
in normal mode. In normal mode, the MPC823 automatically switches to the DFNH 
frequency. To select the DFNH frequency, load this field with the divide value and clear the 
CSRC bit. A loss-of-lock condition will not occur when you change the value of this field. This 
field is cleared by a power-on or hard reset. 


000 = Divide by 1. 
001 = Divide by 2. 
010 = Divide by 4. 
011 = Divide by 8. 
100 = Divide by 16. 
101 = Divide by 32. 
110 = Divide by 64. 
111 = Reserved. 


DFLCD—Division Factor of LCDCLK 


This field sets the VCOOUT frequency division factor for the LCDCLK signal. The total 
division factor of DFALCD and this field should not exceed 64, as defined in 

Section 5.3.4.4 The LCD Clocks. A loss-of-lock condition does not occur when you change 
the value of this field. This field is cleared by a power-on or hard reset. 


000 = Divide by 1. 
001 = Divide by 2. 
010 = Divide by 4. 
011 = Divide by 8. 
100 = Divide by 16. 
101 = Divide by 32. 
110 = Divide by 64. 
111 = Reserved. 


DFALCD—Division Factor of LCDCLK50 


This field sets the LCDCLK frequency division factor for the LCDCLK50 signal. The 
LCDCLKS5O signal is input to the LCD panel. The total division factor of DFLCD and this field 
should not exceed 64, as defined in Section 5.3.4.4 The LCD Clocks. Changing the value 
of this field does not result in a loss-of-lock condition. This field is cleared by a power-on or 
hard reset. : 


00 = Divide by 1. 
01 = Divide by 3. 
10 = Divide by 5. 


11 = Divide by 7. 


5-6 MPC823 USER’S MANUAL MOTOROLA 


Clocks and Power Control 


5.2.2 PLL, Low-Power, and Reset Control Register 


The 32-bit system PLL, low-power, and reset control register (PLPRCR) is powered by a 
keep-alive power supply and is used to control the system frequency and low-power mode 
operation. 


PLPRCR 








Pose Rosas 


(IMMR & OxFFFFO000) + 0x286 


NOTE: HRESET is hard reset and POR is power-on reset. 
—— Undefined. 
Depends on the combination of MODCK1and MODCkK2. See Table 5-2 for more information. 


MF—Multiplication Factor | 


The output of the voltage control oscillator (VCO) frequency is divided to generate the 
feedback signal that goes to the phase comparator. This field controls the value of the 
divider in the SPLL feedback loop. The phase comparator determines the phase shift 
between the feedback signal and the reference clock. This difference results in an increase 
or decrease of the VCO output frequency. 


The MF field can be read and written at any time. Changing the MF field causes the SPLL 
to lose its lock. All clocks are disabled until the SPLL reaches lock condition. The normal 
reset value for the DFNH bits is 0x0 (divide-by-one). When the SPLL is operating in 
one-to-one mode, the MF field is set to 0. See Table 5-2 for details. 


Bits 12—15—Reserved 
These bits are reserved and should be set to 0. 
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SPLSS—System PLL Lock Status Sticky 


This bit is not affected by hard reset. An out-of-lock indication sets the SPLSS bit and it 
remains set until the software clears it. At power-on reset, the state of the SPLSS bit is zero. 
Write a 1 to clear this bit (writing a zero has no effect). Notice that a loss-of lock caused by 
a change in the MF field or the processor entering deep-sleep mode or power-down mode 
does not affect the SPLSS bit. Only a loss-of-lock caused by the following conditions will set 
this bit. 


0 = SPLL remains locked. 
1 = SPLL has gone out of lock at least once since the bit was cleared or at the last 
power-on reset. 


TEXPS—Timer Expired Status 


This internal status bit is set when the periodic timer expires, the real-time clock alarm sets, 
the timebase clock alarm sets, the decrementer interrupt occurs, or the system resets. The 
TEXP pin reflects the value of the TEXPS bit, so you have to read the pin to find out the 
status of the bit. You can clear this bit by writing a 1 (writing a zero has no effect). When 
TEXPS is set, the TEXP external signal is asserted and when it is reset, the TEXP external 
signal is negated. 


O= TEXP is negated. 
1 = TEXP is asserted. 


Bits 18, 20, and 27—31—Reserved 
These bits are reserved and should be set to 0. 


TMIST—Timers Interrupt Status 


This bit is cleared at reset and is set when a real-time clock, periodic interrupt timer, 
timebase, or decrementer interrupt occurs. You can clear this bit by writing a 1 (writing a 
zero has no effect). When the TMIST bit is set, the system clock switches to high frequency, 
as defined by the DFNH field. The system clock frequency stays high if the CSRC bit is set 
and there is no reason to switch to normal low mode. 


O= No timer interrupt is detected. 
1 = A timer interrupt is detected. 


CSRC—Clock Source 


This bit specifies whether the DFNH or DFNL field generates the general system clock. This 
bit is cleared by a hard reset. 


O = The general system clock is generated by the DFNH field. 
1 = The general system clock is generated by the DFNL field. 
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_LPM—Low-Power Modes 


This bit, in conjunction with the TEXPS and CSRC bits, specifies the operating mode of the 
core. There are seven possible modes. In the normal mode, you can write a non-zero value 
to this field. In the other modes, only a reset or interrupt (that is not from the interrupt 
controller) can clear this field. 


00 = Normal high/normal low mode. 
01 = Doze high/doze low mode. 

10 = Sleep mode. 

11 = Deep sleep/power-down mode. 


CSR—Checkstop Reset Enable 


This bit enables an automatic reset when the processor enters checkstop mode. If the 
processor enters debug mode at reset, then reset is not generated automatically. Refer to 
Section 20.6.3.2 Debug Enable Register for more information. 


CSR BIT CHSTPE BIT CHECKSTOP RESULT 
IN DER MODE 






LOLRE—Loss-of-Lock Reset Enable 


This bit enables hard reset generation when a loss-of-lock indication occurs, but not as a 
result of altering the MF field or the processor entering deep-sleep or power-down mode. 


O= A hard reset is not generated when a loss-of-lock is indicated. 
1 = A hard reset is generated when a loss-of-lock is indicated. 


FlOPD—Force I/O Pull Down 


This bit indicates when the address and data external pins are driven by an internal 
pull-down device in sleep and deep-sleep mode. 


O = No pull-down on the address and data bus. 
1 = Address and data bus is driven low in sleep and deep-sleep mode. 
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5.3 THE CLOCK MODULE 


The input frequency source for the phase-locked loop can either be a low frequency crystal 
(32kHz or 38.4kHz) or a high frequency oscillator (8-5MHz) that the phase-locked loop 
multiplies to produce the system clock. If you use a low frequency crystal circuitry, the 
on-chip main clock oscillator requires an external parallel resonant crystal, two capacitors, 
and two resistors, as shown in Figure 5-2. When you design and implement this circuitry, 
follow normal high-frequency design rules for placement and layout. 








32 or 38KHz CRYSTAL 
= 


EXTCLK 


XTAL| 3-5MHz | 
OSC ' - *XFC must be a low-leakage capacitor. See Section 22 Electrical Characteristics for recommended values. 


Figure 5-2. Crystal Oscillator 





If you use a high-frequency oscillator, its output can be directly input to the EXTCLK pin. 

Even though crystals are typically much cheaper, oscillators have more stability because 
they are less affected by trace length, Gonenm quality, printed circuit board layout and 
characteristics. 


gp —=s Note: = In your design, you should always consider the oscillation startup stablization 
time of the crystal. During this stabilization time, no internal or external clocks are 
generated by the MPC823, which may cause higher than normal static current 
during the short period of stabilization. Assuming that the crystal circuit is 
powered by keep-alive power, then once you system has had first time power- 
up, allowance for stabilization is not necessary. 


The MPC823 clock module consists of the main crystal oscillator, the SPLL, the low-power 
divider, the clock generator/driver blocks, and the clock module/system low-power control 
block. The clock module and system low power control block receive control bits from the 
system clock control register (SCCR), PLL low-power and reset control register (PLPRCR), 
and reset status register (RSR). Figure 5-3 illustrates the clock module. 
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Figure 5-3. Clock Module Diagram 
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5.3.1 On-Chip Oscillators and External Clock Input 


The main clock oscillator (OSCM) uses either a 3-5MHz source at EXTCLK (4MHz mode) 
oscillator or a 30-50kKHz (82kHz mode) crystal between EXTAL and XTAL to generate the 
SPLL reference clock (OSSCLK). The external clock input EXTCLK is generated from an 
external source. In one-to-one mode, the input clock frequency must be at least 15MHz. 
Otherwise, it can be between 3 and 5MHz. See Figure 5-1 for details. 


For normal operation, at least one clock source should be active, but it is possible to 
configure both clock sources to be active. When both clock sources are active, the EXTCLK 
pin provides the OSCCLK signal for the SPLL. The EXTAL and XTAL pins provide the input 
frequency for the OSCM that generates the PITRTCLK signal. The input of an unused timing 
reference should be grounded. 


Note: Under any condition, the voltage on the MODCK1 and MODCK2 pins should be 
less than or equal to the power supply voltage VDDH applied to the part. 


5.3.2 System PLL 


The main purpose of the SPLL is to generate a stable reference frequency by multiplying 
the frequency and eliminating the clock skew. The SPLL allows the processor to operate at 
a high internal clock frequency using a low frequency clock input, which gives you two 
advantages. Lower frequency clock input reduces the overall electromagnetic interference 
generated by the system. Also, oscillating at different frequencies reduces the cost because 
you will not have to add more oscillators to your system. The MPC823 SPLL block diagram 
is illustrated in Figure 5-4. 


XFC 


UP 7 4 
CHARGE 
PUMP 


PHASE 
COMPARATOR | DOWN i 









OSCCLK 
VCOOUT 











FEEDBACK 









MULTIPLICATION FACTOR 
| MFIO:11] | 


Figure 5-4. SPLL Block Diagram 
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The OSCCLK signal goes to the phase comparator that controls the direction in which the 
charge pump drives the voltage across the external filter capacitor (XFC). Direction is based 
on whether the feedback signal phase lags or leads the reference signal. The output of the 
charge pump drives the VCO whose output frequency at VCOOUT is divided down and fed 
back to the phase comparator to be compared with the reference frequency (OSCCLK 
signal). The multiplication factor should be between 1 and 4,096. Also, when the SPLL is 
operating in one-to-one mode, the multiplication factor is 1 (the MF field equals 0). 


At the initial system power-up after keep-alive power is lost, external logic should assert the 
PORESET pin for 3us after a valid level is reached on the keep-alive power supply. When 
power-on reset is asserted, the MF field is set as shown in Table 5-1 and the DFNH and 
DFNL fields are both set to 0. This MF field value then programs the SPLL to generate the 
approximate default system frequency of 16.7MHz when a 32kHz input frequency is used 
and 20MHz when a 4MHz input frequency is used. 


Table 5-1. Power-On Reset Clock Configuration 


MODCK [1:2] DEFAULT SPLL OPTIONS 
MF +1 AT 
POWER-ON RESET 


Normal operation, SPLL enabled. 
Main timing reference is OSCMtreg = 32 KHz. 











Normal operation, SPLL enabled. 
Main timing reference is OSCMfreq = 4 MHz. 


Normal operation, SPLL enabled. 
Main timing reference is EXTCLKfreg= 4 MHz. 


Normal operation, SPLL enabled. 
One-to-one Mode Maximum 
CLKOUT freq = EXTCLK freq 


5.3.2.1 SPLL STABILITY. The SPLL can multiply the input frequency by any integer that is 
between 1 and 4,096. The multiplication factor can be changed by modifying the value of 
the MF field in the PLPRCR. Even though any multiplication factor between 1 and 4,096 can 
be programmed, the resulting VCO output frequency must be within the range specified in 
Section 22 Electrical Characteristics. The MF field in the PLPRCR is set toa 
predetermined value when a power-on reset occurs. The multiplication factor is the most 
important parameter and as it goes higher it has a greater effect on the stability of the SPLL. 
There are three factors that define SPLL stability—phase skew, phase jitter, and frequency 
jitter. 


The phase skew is the time difference between the falling edges of the EXTAL and CLKOUT 
pins for a capacitive load on CLKOUT over the entire process, temperature ranges, and 
voltage ranges. For input frequencies greater than 15MHz and MF<2, this skew is between 
-0.9ns and +0.9ns. Otherwise, this skew is not guaranteed. However, for MF<10 and input 
frequencies greater than 10MHz, the skew is between -2.3ns and +2.3ns. 
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_ The phase jitter is a variation in the skew that occurs between the falling edges of the EXTAL 


and CLKOUT pins for a specific temperature, voltage, input frequency, MF, and capacitive 
load on the CLKOUT pin. These variations are a result of the PLL locking mechanism. For 
input frequencies greater than 15MHz and MF<2, this jitter is less than +0.6ns. Otherwise, 

this jitter is not guaranteed. However, for MF<10 and input Meee greater ney 10MHz, 
this jitter is less than +2ns. | | 


The frequency jitter is defined as the frequency variation of the CLKOUT pin. For small 
multiplication factors (MF<10), this jitter is smaller than 0.5%. For mid-range multiplication 
factors (10<MF<500), this jitter is between 0.5% and -2%. For large multiplication factors 
(MF>500), the frequency jitter is 2-3%. The maximum input frequency jitter on the EXTAL 
pin is 0.5%. If the rate of change of the frequency at the EXTAL pin is slow (it does not jump 
between the minimum and maximum values in one cycle), the maximum jitter can be 2%. 


5.3.3 The Low-Power Clock Divider 


The output of the SPLL is sent to a low-power divider that generates other clocks for normal 
operation, but also has the ability to divide the output frequency of the VCO before it 
generates the SYNCCLK, LCDCLK, LCDCLK50, BRGCLK, and GCLKx (which is sent to the 
rest of the MPC823). GCLKxC is the system timing reference for the core, instruction and 
data caches, and memory management unit. GCLKx is the system timing reference for the 
other modules. GCLKx_50 operates at a frequency that is half the GCLKx frequency. The 
frequency ratio between GCLKx and GCLKx_50 is determined by the EBDF bit in the SCCR. 
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Figure 5-5. Clock Dividers 





The low-power dividers allow you to reduce and restore the operating frequencies of 
different sections of the MPC823 without losing the SPLL lock. Using the low-power dividers, 
you can still obtain full chip operation, but at a lower frequency. This is called normal low 
mode. You can switch to normal low mode or set the speed at any time and the changes 
you make will occur immediately. The low-power dividers are controlled by the SCCR and 
its default division factor is divide by one at reset. For a 40MHz system, SYNCCLK, 
LCDCLK, LCDCLK50, BRGCLK, and GCLKx are all 40MHz at reset. 
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5.3.4 Internal Clock Signals 


The internal logic of the MPC823 uses the following internal clock signals: 


e General system clocks 

e Baud rate generator clock 
e Synchronization clocks 

e LCD clocks 


The MPC823 also generates an external clock signal called CLKOUT. All internal clock 
signals originate from the same source, so they are all synchronized to VCOOUT. 


5.3.4.1 THE GENERAL SYSTEM CLOCKS. The general system clocks—GCLK1C, 
GCLK2C, GCLK1, GCLK2, GCLK1_50, and GCLK2_50—are the basic clocks supplied to 
all modules of the MPC823. GCLKXxC is supplied to the core, data and instruction caches, 
and memory management unit. It is not active when the core is in sleep or power-down 
mode. GCLKx is supplied to the system interface unit, clock module, memory controller, and 
most of the other blocks in the communication processor module. | 


The timing relationship between the general system clock signals that are shown in 
Figure 5-1 is illustrated in Figure 5-6. CLKOUT, the only externally visible clock, is derived 
from the GCLK2_50 signal. 


GCLK1 | | 


GCLK2 ) | 


GCLK1_50 
(EBDF=00) 

| | | | | | 
GCLK2_50 | | | 
(EBDF=00) | | | 

| 
CLKOUT | | | | | 
(EBDF=00) | | 

| 


| | 
GCLK1_50 | - | | 
_ (EBDF=01) 
GCLK2.50 | | a: | | 
(EBDF=01) | | | | | | 

| | | 

CLKOUT | | | ~? 7] | | 
(EBDF=01) 7 


Figure 5-6. MPC823 Clocks Timing Diagram 
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Notice that GCLK1_50, GCLK2_50, and CLKOUT can have a lower frequency than GCLK1 
and GCLKk2. This allows the external bus to operate at lower frequencies as controlled by 
the EBDF bit in the SCCR. GCLK2_50 always rises simultaneously with GCLK2. GCLK1_50 
rises simultaneously with GCLK1, but when the MPC823 is not in normal low mode, the 
falling edge of GCLK1_50 occurs in the middle of the high phase of GCLK2_50 and EBDF 
determines the division factor between GCLKx and GCLKx_50. See Figure 5-9 for more 
information. 


The general system clock defaults to VCOOUT frequency at system reset. In normal low 
mode, the frequency of the general system clock can be dynamically switched using the 
SCCR. 








VCOOUT DFNH DIVIDER 


DFNL DIVIDER 


LOW POWER MODE | 


Figure 5-7. Selecting the General System Clock 


You can switch the general system clock division factor between two different values (DFNH 
and DFNL). The high frequency is generated by using the DFNH field in the SCCR and it is 
used in normal high and doze high mode. The low frequency is generated using the DFNL 
field in the SCCR and it is used in normal low and doze low mode. Conventionally, to 
conserve power low frequency is slower than high frequency. 


In some applications, a high frequency is needed to perform critical tasks. For example, 
interrupt routines need to be run at a high frequency, but the rest of the application can run 
at a low frequency to conserve power. The MPC823 can automatically switch between low 
and high frequency operation when one of the following conditions exist: 
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e A pending interrupt from the interrupt controller occurs. This option is maskable by the 
PRQEN bit in the SCCR. 


e The POW bit of the machine status register is clear. This option is maskable by the 
PRQEN bit in the SCCR. 


e The RISC microcontroller in the communication processor module has a pending 
request or is currently executing a routine. This option is maskable by the CRQEN bit 
in the SCCR. 
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When none of these conditions exist and the CSRC bit of the PLPRCR is set, the general 
system clock automatically switches back to low frequency. When the general system clock 
is divided, its duty-cycle is modified. One phase remains the same while the other stretches 
out. GCLKx and CLKOUT no longer have a 50% duty cycle when the division factor is 
greater than 1, as shown in Figure 5-8 and Figure 5-9. 


GCLK1 DIVIDED BY 2 | | | | | | | | | | 
GCLK2 DIVIDED BY 2 | | | | | | | | | | 
GCLK1 DIVIDED BY 4 | | | | | | 


GCLK2 DIVIDED BY 4 | | | | | | | 


Figure 5-8. Divided System Clocks Timing Diagram 


GCLK1 | | 


, | 7 | | 
GCLK2 | | | | 
| 
GCLK1_50 a 
(EBDF=00) | 
~ @cukeso | | | | ; 
(EBDF=00) | | | | | 
| 


CLKOUT | 
(EBDF=00) | 


| | | | 
| | 
| | 
GCLK1_50 | | | 
(EBDF=01) | | 
GCLK2_50 | | | | 
(EBDF=01) | | | | 
| | 
CLKOUT | | | : 
(EBDF=01) | 
| 


Figure 5-9. MPC823 Clocks For Division Factor 2 
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The frequency for the GCLKx system clock is: 


VCOOUT 


DFNH DFNL +1 


The frequency for the GCLKx_50 system clock is: 
VCOOUT jeg 


DFNH DFNL#1) EBDF +1 


GCLKx_50 = 
ed (2 yor(2 


CLKOUT is derived from GCLK2_50. It defaults to VCOOUT, which is the user-defined 
system frequency (25 or 50MHz). CLKOUT can drive at full-strength, half-strength, or it can 
be disabled. The strength of the drive is controlled in the system clock and reset control 
register. Disabling or decreasing the strength of CLKOUT reduces power consumption, 
noise, and electromagnetic interference on the printed circuit board. When the SPLL is 
acquiring lock, the CLKOUT signal is disabled and remains in a low state. 








GCLK1 
PHASE 
GCLK2_50 


CLKOUT 


Figure 5-10. CLKOUT Divider 


5.3.4.2 THE BAUD RATE GENERATOR CLOCK. The baud rate generator clock 
(BRGCLK) is used by the four baud rate generators of the communication processor module 
and by the memory controller refresh counter. It defaults to VCOOUT, which is the 
user-defined system frequency (25 or 50MHz). The baud rate generator clock allows the 
baud rate generators to continue operating at a fixed frequency, even when the rest of the 
MPC823 is operating at a reduced frequency. Refer to Section 16.8 The Baud Rate 
Generators for more information about using the baud rate generator clock to save power. 


BRGCLK 











VCCOUT 
DFBRG 


CPM, UPM, 
(REFRESH 
TIMER) 


Figure 5-11. BRGCLK Divider 
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The baud rate generator clock frequency is: 
VCOOUT ag : 


(°* DFBRG 


BRGCLKi og - 


5.3.4.3 THE SYNCHRONIZATION CLOCKS. The synchronization clock signal 
(SYNCCLK) is used by the serial synchronization circuitry in the serial ports of the 
communication processor module that includes the serial interface, serial communication 
controller, and serial management controllers. SYNCCLK defaults to VCOOUT, which is the 
user-defined system frequency (25 or 50MHz). 


VCCOUT -—DFSYNC SYNCCLK , CPM 


Figure 5-12. SYNCCLK Divider 


SYNCCLK allows the serial interface, serial communication controller, and serial 
management controllers to continue operating at a fixed frequency, even when the rest of 
the MPC823 is operating at a reduced frequency. This allows you to maintain the serial 
synchronization circuitry at the preferred rate, while lowering the general system clock to the 
lowest possible rate. SYNCCLK must always have a frequency at least as high as the 
general system clock frequency and be at least two times the preferred serial clock rate. If 
the time-slot assigner in the serial interface is used, SYNCCLK is at least two and half times 
the preferred serial clock rate. Refer to Section 16.7 The Serial Interface with Time-Slot 
Assigner for more information on how to select an appropriate frequency for SYNCCLK. 
The synchronization clock frequency is: 


VCOOUT tag 


2 x DFSYNC. 


SYNCCLK eq = 
(2 ) 
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5.3.4.4 THE LCD CLOCKS. The LCD clocks—LCDCLK and LCDCLK50—are used by the 
LCD controller circuitry to transfer the frame data to pixel format data. LCDCLK defaults to 
VCOOUT, which is the user-defined system frequency (25 or 50MHz).When the PON bit in 
the LCCR is set, the ratio between the system clock frequency value and the LCD clock 
frequency value should be an integer value. The LCD clock frequency is the system 
frequency divided by two serial dividers. LCDCLK50 is a 50% duty-cycle clock at the same 
frequency as LCDCLK that is used as a clock output to the LCD panel. DFLCD and DFALCD 
should be set so that the total LCD clock division factor never exceeds 64. 


LCD/VIDEO 
CONTROLLER 


LCD PANEL 


LCDCLK 









LCDCLK50 


mcs DFLCD DFALCD 


Figure 5-13. LCDCLK Divider 


The LCDCLK and LCDCLK50 frequency is: 
VCOOUT 6, 


DFLCD 


LODCLK i 6, = LODCLK50;,, oS 
(2 ) x (2 x DFALCD + 1) 


qackepMiDEBY! =9_J LJ LJ LIL LU U UU us] 
LopeLkIviDEBYt =§_ {| LJ LJ LI LILI UU LU U Ud 
tepeiksopwibEBY? — [LE LET LPLPLrLPlr_rl_ly 
GCLK2 DIVIDE BY 2 [ | [ iz | | | | 
LCDCLK DIVIDE BY 2 [| [| rd r | l 
LCDCLKSODIVIDEBY2 [{ | f|f | | | f | fd. 
GCLK2 DIVIDE BY 4 [| im @ 


LCDCLK DIVIDE BY 4 
LCDCLK50 DIVIDEBY4 —_| | | | | | 
Figure 5-14. LCD Clock Timing Diagram 
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5.3.5 Clock Configuration 
You can configure the clock of the MPC823 using the MODCK1 and MODCK2 pins. The 


SPLL has several power and ground pins (VDDSYN, VSSSYN, VSSSYN1, and XFC) that 


must be properly terminated for stability and CLKOUT integrity. 


5.3.5.1 MODE CLOCK PINS. The MODCK1 and MODCkKz2 pins are used to determine 
clock source and configuration options. These pins are sampled on the rising edge of the 
PORESET pin. MODCK1 specifies the input source to the SPLL and, combined with 
MODCkz2, specifies the multiplication factor at reset. If you do not want the PITRTCLK, 
TMBCLK, and multiplication factor to change during power-down mode, do not sample the 
MODCK1 and MODCKz2 pins during wake-up. Thus, the PORESET pin should remain 
negated while the HRESET pin is asserted during this wake-up sequence. 


Table 5-2. Reset Clock Source Configuration 


MODCK | POWER-ON | DEFAULT | PITRTCLK | TMBCLK SPLL OPTIONS 
[1:2] DIVISION DIVISION 


Normal operation, SPLL enabled. 
Main timing reference is OSCMfreg = 32 kHz. 


Normal operation, SPLL enabled. 


Main timing reference is OSCMfreg = 4 MHz. 


Normal operation, SPLL enabled. 
Main timing reference is EXTCLK¢reg = 4 MHz. 


Normal operation, SPLL enabled. 
One-to-one Mode, Maximum 
CLKOUT freq = EXTCLKtreg 





The configuration remains unchanged. 


MODCK1 selects the clock source to use (EXTCLK or main oscillator) and MODCkK2 selects 
the reference frequency (4MHz, 32kHz, or EXTCLK). If, during the power-on reset 
sequence, the MODCK1 pin is zero, then the oscillators 4MHz or 32kHz clock is the 
selected input. lf MODCK1 is one, then the EXTCLK pin is the input source to the SPLL. The 
system clock frequency (GCLK1) can be divided as defined by the DFNH and DFNL fields 
in the SCCR. The maximum system clock frequency occurs when the DFNH field is equal 
to 00. If MODCK2 is zero during the power-on reset sequence, the input frequency is either 
32kHz or EXTCLK (one-to-one mode). If the MODCK2 pin is one, then a 4MHz clock is the 
input source to the SPLL. 


If the EXTCLK pin is the main timing reference and the OSCM is the timing reference to the 
real-time clock and periodic interrupt timer, then the frequency of the OSCM should be 
32.768 or 38.4kHz. Depending on how the TBS bit is set in the SCCR, the timebase clock 
is either the SPLL clock frequency or GCLK2. The RTSEL field in the SCCR specifies the 
source (EXTCLK or OSCM) of the periodic interrupt timer and real-time clock. The RTDIV 
field in the SCCR specifies the division factor (+ by 4 or + by 512). 
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Table 5-3. TMBCLK Dividers 


a CS 
SO 
a 
a 


5.3.5.2 THE SYSTEM PHASE-LOCKED LOOP PINS. The internal frequency of the 
MPC823 and the output of the CLKOUT pin depends on the quality of the crystal circuit and 
the MF bit in the PLPRCR. The SPLL contains the following dedicated pins that are isolated 
from common power and ground. 











e VDDSYN—The power supply pin for the analog SPLL circuitry. You should provide a 
well-regulated voltage to this pin via an extremely low impedance path to the VDD 
power rail. The SPLL power plane must be isolated from the VDD power plane with an 
LC filter, which gives you the best performance. A 0.1LLF bypass capacitor must 
connect VDDSYN and VSSSYN and be as close to the chip as possible. To reduce the 
noise from the open EXTAL pin, pull it to ground when you are not using it. 


e VSSSYN—A ground reference pin for the analog SPLL circuitry. You should provide a 
low impedance path from VSSSYN to the ground plane. | 


e VSSSYN1—A ground reference pin for the analog SPLL circuitry. You should provide 
a low impedance path from VSSSYN1 to the ground plane. 


e XFC—The external filter capacitor pin that connects to the off-chip capacitor for the 
SPLL filter. One terminal of the capacitor is connected to XFC while the other terminal 
is connected to the VDDSYN pin. For proper SPLL operation, you should supply a 
minimum parallel parasitic resistance value of 30MQ. The value of the XFC capacitor is 
based on the value of the MF field in the PLPRCR. 


Table 5-4. XFC Capacitor Values Based on the MF Field 
MINIMUM MAXIMUM UNIT 
CAPACITANCE CAPACITANCE 
XFC = (MF x 425)-125 | XFC = (MF x 590) - 175 
XFC = MF x 520 XFC = MF x 920 
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5.4 POWER CONTROL 


To preserve the life of your battery, the MPC823 provides low-power modes that limit the 
operation to essential modules. In addition to normal high mode, the MPC823 supports 
normal low, doze high, doze low, sleep, deep-sleep, and power-down modes. When the 
CPM is idle, it uses its own power-saving mechanism to shut down automatically. There are 
a variety of modules connected to separate power rails that allow you to achieve the best 
performance using the least amount of power. — 


5.4.1 Power Rails 


There are different power planes (called power rails) within the MPC823 that can be 
connected to different power sources. Your system implementation defines the power 
source for each of these different power rails. Figure 5-15 shows you which module is 
connected to each power rail. 







"woes 







- INTERNALLOGIG. 
AND CLOCK DRIVERS. 


VDDH 


VDDL VDDSYN 
Figure 5-15. MPC823 Power Rails and TEXP Status 


The I/O buffers, logic, and clock control are fed by a 3.3V (410%) power supply. The internal 
logic can be fed by a 3.3V source or, to conserve power, a 2.2V source. To improve 
CLKOUT stability, the SPLL requires a separate 3.3V source (VDDSYN). The OSCM, 
timebase, decrementer, periodic interrupt timer, real-time clock, SCCR, PLPRCR, and RSR 
are all connected to the keep-alive power (KAPWR) rail. This power rail architecture allows 
you to remove the power at the VDDH/VDDL/VDDSYN pins during sleep, deep-sleep, or 
power-down mode. The external power supply unit can use the TEXP pin, which is fed by 
the KAPWR rail, to switch between power sources. 
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All other circuits are powered by the normal supply pins—VDDH and VDDL—and VSS. 
VDDH feeds the I/O buffers and logic and VDDL supplies the internal chip logic to reduce 
system power consumption. However, the power supply connected to VDDH should be 
larger or equal to the one connected to VDDL. The power supply for each block is listed in 
Table 5-5 and described in Section 5.4 Power Control. 


Table 5-5. MPC823 Power Supply 


BLOCK VDDH VDDL VDDSYN )  KAPWR 
X 







ae a 


Clock Control 







Internal Logic 






Clock Drivers 






OSCM 






SCCR, PLPRCR, and RSR 
RTC, PIT, TB, and DEC 









The following are the power supply requirements of the MPC823: 


VDDH = VDDSYN = 3.3V +10% 

VDDH 2 VDDL 2 2.2V +10% 

VDDH 2 KAPWR 2 VDDH - 0.4V for normal operation 
KAPWR 2 2.2V +10% in power-down mode 


5.4.2 Keep-Alive Power 


When the MPC823 is in normal operation mode, the keep-alive power supply (KAPWR) is 
powered to the same voltage value as that of the I/O buffers and logic. Therefore, if the 
VDDL is 2.2V and the VDDH is 3.3V, then the KAPWR is 2.9V to 3.3V. 
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5.4.2.1 POWER SWITCHING EXAMPLE. An example of a switching scheme for an 
optimized low-power system is illustrated in Figure 5-16. 


Deny no ee es ee 








MAIN POWER 
VDDSYN SUPPLY 





3.3V 2.2V 






MPC823 






2.4-3.3V 


BACKUP 
POWER 
SUPPLY 








Figure 5-16. External Power Supply Scheme (2.2V Internal Voltage) 


Switch 1 and 2 (SW1 and SW2) can be combined into a single switch if VDDSYN and VDDH 
are supplied by the same source. If VDDL is fed with 3.3V, SW2 and SW3 can be combined 
into one switch. The TEXP pin, if enabled, is asserted by the MPC823 when the real-time 
clock or timebase time value matches the value programmed in its associated alarm register 
or when the periodic interrupt timer or decrementer decrements their value to zero. The 
TEXP pin is negated when you write a 1 to the TEXPS bit in the PLPRCR. 


If the voltage to the KAPWR rises too slow, the OSCM (supplied by KAPWR) will take longer 
to stabilize the OSCCLK. The maximum KAPWR rise time should be less than 1.7V/ms for 
a 32kHz input frequency. 
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5.4.2.2 REGISTER LOCK. The MPC823 registers that are powered by KAPWR can be 
write-protected using the associated key register shown in Table 5-6. When the MPC823 
disconnects from the main power supply after it enters power-down mode, the value of these 
registers is automatically preserved. You may lose data if you do not enter power-down 
mode before disconnecting. To protect your data, lock the register by writing to the 
associated key register. Once you lock a register, writes are ignored and a machine check 
exception is generated. 


Table 5-6. Key Registers 


NOTE: Refer to Section 3 Memory Map for each register’s address. 
























Each of the registers in the keep-alive power region have a key register that can be in an 
open or locked state. At power-on reset, all key registers are open, except for the key 
real-time clock registers. Each key register has an associated address in the internal 
memory map, as shown in Table 3-1. If you write Ox55CCAA33 to any of the key registers, 
the associated register will be open and if you write any other value it will be locked. For 
example, writing a Ox55CCAA33 to the RTCK key register will allow you to access the RTC 
register. 
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POWER-ON RESET we 


OPEN 


WRITE 0x55CCAA33 TO 
WRITE ANY OTHER VALUE TO 
THE KEY REGISTER THE KEY REGISTER 


LOCKED 


Figure 5-17. Register Lock Mechanism 


5.5 LOW-POWER OPERATION 


The low-power dividers can be used to take advantage of the MPC823’s low-power 
capabilities. The low-power dividers allow you to dynamically adjust the operating 
frequencies for different modules of the MPC823 and yet still maintain the SPLL lock. In 
normal low mode, you can use the low-power dividers to maintain full chip functionality, but 
at a much lower frequency. When you change the value of the divider, the resulting output 
frequency occurs immediately. The low-power dividers are controlled in the SCCR and their 
default division factors are one. For example, ina 50MHz system frequency, the SYNCCLK, 
LCDCLK, LCDCLK50, BRGCLK, and GCLKx are all 50MHz. 


You can switch between the various low-power modes, as illustrated in Figure 5-18. Your 
software must set the appropriate CSRC and LPM fields in the PLPRCR and the POW bit 
in the MSR so the MPC823 can enter doze, sleep, or power-down mode from a normal 
mode. The MPC823 uses an interrupt to exit from any of these lower power modes. An 
enabled interrupt clears the LPM field, but does not change the CSRC bit. An interrupt 
switches automatically to normal high mode from normal low, doze high, doze low, sleep, or 
deep-sleep mode. Interrupts are generated by: 


e Wake-up interrupts (IRQ signal) from the interrupt controller. 
e Real-time clock, periodic interrupt timer, timebase, or decrementer interrupts. 
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CRQEN & CPM_ACT | PRQEN & (POW | INTERRUPT) | CSRC 
ee Se 








NORMAL LOW MODE (PRQEN | POW & INTERRUPT) & CRQEN | CPM_ACT) & CSRC*}* 


LPM = 00, CSRC = 1 


DOZE LOW MODE 


LPM = 01, CSRC = 1 





INTERRUPT 
CPM_ACT & CSRC WAKE-UP: MAXIMUM 2-4 GCLK1 
CLOCKS 
DOZE HIGH MODE INTERRUPT 


LPM =01, CSRC =0 OR 1 


00, 
0 OR 1 


WAKE-UP: 3-4 VCOOUT 
SOFTWARE * CLOCKS 





LPM 


HIGH MODE 
CSRC 


NORMAL 


SLEEP MODE 
LPM = 10, CSRC =0 








WAKE-UP OR RTC/PIT/TB/DEC 
DEEP-SLEEP MODE INTERRUPT 
LPM = 11, CSRC = 0, 
POWER-DOWN MODE 
LPM =11, CSRC=0, EXTERNAL HARD RESET OR 
_ yt RTC/PIT/TB/DEC INTERRUPT 
ebes FOLLOWED BY AN 
EXTERNAL HARD RESET 
HARD RESET 


NOTE: “&” DENOTES “AND” OPERATION, “I” DENOTES “OR” OPERATION, AND CPM_ACT DENOTES CPM ACTIVITY. 
* SOFTWARE IS ACTIVE ONLY IN NORMAL HIGH/LOW MODES. 
** ‘TEXPS RECEIVES THE ZERO VALUE BY WRITING A ONE TO IT. WRITING A ZERO HAS NO EFFECT ON TEXPS. 
** YOU CAN SWITCH FROM NORMAL HIGH TO NORMAL LOW ONLY IF THE CONDITIONS TO AN INTERRUPT ARE CLEARED. 


Figure 5-18. MPC823 Low-Power Mode Flowchart 
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The system responds quickly to an interrupt that does not come from the interrupt controller. 


The wake-up time from normal low, doze high, doze low, or sleep mode is between three 


and four VCOOUT clocks. For example, it could take 60-80ns to wake up in a 50MHz 
system. The level-sensitive interrupt from the interrupt controller is defined as a wake-up 
interrupt. It is only negated after the interrupt source bit is cleared. Any of the real-time clock, 
periodic interrupt timer, timebase, or decrementer interrupts can set the TMIST bit in the 
PLPRCR. The MPC823 clock module recognizes this interrupt as a pending interrupt when 
the TMIST bit is set. Therefore, the TMIST bit should be cleared before you enter any low- 
power mode other than normal high mode. 


The wake-up time for all interrupt sources from the interrupt controller is measured in actual 


~GCLK1 clocks. Once the interrupt is recognized, it takes between two and four GCLK1 


clocks for the MPC823 to reach normal high mode. For example, it could take between 
10.24us and 20.48us to wake up in a 50MHz system where DFNL = 111 (divided by 256). 
In normal and doze modes when the CSRC bit is set, the system toggles between the low 
and high frequencies. One of the following conditions must be met before you can switch 
from normal low mode to normal high mode. 


e The communication processor module must be active (CPM_ACT) 
e A pending interrupt from the interrupt controller must be recognized (INTERRUPT) 
e The POW bit in the MSR must be cleared (normal operation) (POW) 


If none of these conditions are met, the CSRC bit is set, and the interrupt status bits are 
reset, then the system automatically switches back to normal low mode. If the 
communication processor module is active, the system automatically switches from doze 
low mode to doze high mode. On the other hand, when the communication processor 
module is idle and the CSRC bit is set, then the system automatically switches back to doze 
low mode. A pending interrupt from the interrupt controller transfers the system from doze 
mode to normal high mode. The MPC823 exits deep-sleep mode and enters normal high 
mode when a wake-up interrupt from the interrupt controller, real-time clock, periodic 


interrupt timer, timebase, or decrementer is recognized. 


In deep-sleep mode the SPLL is disabled and, therefore, the wake-up time from this mode 
is a maximum of 500 OSCM clocks. In 1-to-1 mode, the wake-up time can be a maximum 
of 1,000 EXTCLK clocks. For example, if the SPLL input frequency is 32kHz, the wake-up 
time is a maximum of 15.6ms and if it is 4MHz in 1-io-1 mode, ine wake-up time is a — 
maximum of 125us. | 


To exit power-down mode and enter normal high mode, the HRESET pin must be asserted 
by external logic when the TEXP pin is asserted. The TEXPS bit in the PLPRCR is 
automatically set when a wake-up interrupt from the real-time clock, periodic interrupt timer, 
timebase, or decrementer occurs. HRESET should be asserted longer than the time it takes 
the power supply to wake up, plus the time it takes for the SPLL to reach lock condition. 
Another way to exit power-down mode is to assert HRESET when the TEXP pin is negated 
and the TEXPS bit is cleared. This causes the MPC823 to automatically assert the TEXP 
pin, which sets the TEXPS bit, and enter normal high mode. 
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When a timer expires, if enabled, the TEXP pin is asserted asynchronously with CLKOUT 
to show that the MPC823 is preparing to exit power-down mode. TEXP should be externally 
connected to a switch that should turn on the power supply to the chip, as illustrated in 
Figure 5-16. 


In normal and doze modes, the system can be in the high mode defined by the DFNH field 
or in the low mode defined by the DFNL field. The MPC823 is in normal high mode after 
reset and this also the default state when the condition to exit low-power mode occurs. 
Table 5-7 provides the power consumption equations for each of these modes. 


Table 5-7. MPC823 Low-Power Modes 


RETURN TIME MPC823 POWER 
OPERATION | SPLL | CLOCKS | WAKE-UP FROM CONSUMPTION FUNCTIONALITY 
MODE METHOD | WAKE-UP EVENT AT 50MHZ 

TO NORMAL HIGH 
Normal High Active | VCOUT ~ DFNH Full Functions Not In 
LPM=00 - i pDENH Soon e W Use Are Shut Off 
TEXPS=1 , 
Normal Low Active | VCOUTteq | Software Asynchronous =20 mW + 1/2(DFNL+1) yw 
LPM=00 oDFNL+1 or Interrupts: = 
TEXPS=1 Interrupt 3-4 VCOOUT Clocks 
Doze High Active | VCOUT Interrupt Synchronous ~ DFNH Enabled: Real-Time 
LPM=01 ° TpDFNA e Interrupts: =e OmW 0.412 ~ Clock, Periodic 
TEXPS=1 2-4 GCLK1 Clocks Interrupt Timer, and 

Memory Controller: 


Doze Low Active | VCOUT Interrupt = (DFNL+1) Disabled: Extended 

aeep LPM=10 | Active Inactive Interrupt 3-4 VCOOUT Clocks <10 mW Enabled: Real-Time 

TEXPS=1 Clock, Periodic 
Interrupt Timer, 


Deep-Slee Inactive} Inactive Interrupt <500 OSCM Clocks 40pA Timebase, and 
LPM=i1 ; 16ms-32kHz . Becrementer 
TEXPS=1 125us-4MHz 
Power-Down | Inactive} Inactive Interrupt <500 OSCM Clocks + 32kHz- ~10nA 
LPM=11 Power Suppl Wake- KAPWR = 3.0V 
TEXPS=0 up (Pw Ps ake+ Temperature = 50° C 

6mMs at 32kHz) 
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Note: The communication processor module has its own power conservation logic, 
which it uses to automatically shut down its own clock when idle. 
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SECTION 6 
THE POWERPC CORE 


The MPC823 core is where the PowerPC™ architecture is implemented. It has the 
functionality of the PowerPC branch processor and fixed-point processor and includes all 
the PowerPC user mode (problem mode) instructions, except floating-point instructions, 
relevant privileged instructions, and all the registers associated with the processors and 
instructions. In addition, it contains part of the development support features of the MPC823, 
including breakpoint and watchpoint support, program flow tracking data generation, and 
debug mode operation in which the core is controlled by the development support system 
through the debug port module. 


This section describes the functional specifications of the core. It is based on a document 
called the PowerPC Microprocessor Family: The Programming Environment for 32-Bit 
Microprocessors (MPCFPE32B/AD). Any reference to 64-bit implementation is not 
supported by this core. Only a subset of the PowerPC architecture books are supported, as 
indicated in Appendix B MPC823 Instruction Set. 


6.1 FEATURES 


The following is a list of the core’s main features: 


e 32-bit PowerPC Architecture 
e Single-lssue Integer Machine | 
Variable Pipeline Depth Architecture Tailored to Instruction Complexity 


Fully Static Design 

e Out-of-Order Execution Termination 

e Branch Prediction for Prefetch 

e 32 x 32-Bit General-Purpose Register File 
e Precise Exception Model 


Extensive Debug/Testing Support 


MOTOROLA _-MPC823 USER’S MANUAL 6-1 








The PowerPC Core 


6.2 BASIC STRUCTURE OF THE CORE 


To accomplish its tasks, the core is divided into the following subunits: 


e Sequencer Unit—Consists of the branch processor (next address generation), the 
instruction prefetch queue, and the interrupt handling mechanism. It controls some data 
structures within the register unit. 


e Register Unit—Consists of all the user-visible registers, the vadister Ss scoreboard 
mechanism, and a history of previous operations to allow for a precise interrupt model. 
This module is physically split so that each data structure is implemented near the area 
in which it is used. 


e Fixed- Point Unit—Implements all fixed- -point instructions, except load/store 
instructions. This module. is subdivided into the following two blocks: 


OY IMUL/IDIV-Fixed-point multiply and divide instruction implementation. 


QO ALU/BFU- Fixed-point logic, add, and subtract instruction implementation, as well 
as the bit field instructions. 


e Load/Store Unit—Implements all load and store instructions. No floating- point 
: pigre ee! load and store instructions are implemented. 


6.2.1 Instruction Flow Within the Core 


When fetched, instructions enter the instruction queue and enable branch folding by © 
allowing out-of-order branch execution. Nonbranch instructions reaching the top of the 
instruction queue are issued to the execution units. Instructions can be flushed from the 
instruction queue in case of an exception on a previous instruction, interrupt, or 
miss-predicted fetch. 


All instructions, including branches, enter the history buffer along with processor state 
information that can be affected by the instruction’s execution. This information is used to 
enable out-of-order completion of instructions together with precise exception handling. 
When exceptions or interrupts occur, instructions can be flushed or recovered from the 
machine. The instruction queue is always flushed when the history buffer is recovered. An 
instruction retires from the machine after it finishes executing without exception and all 
preceding instructions are retired from the machine. Figure 6-1 illustrates the core’ S 
microarchitecture. 
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Figure 6-1. Block Diagram of the Core 
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HISTORY BUFFER 


INSTRUCTION QUEUE 





Figure 6-2. Instruction Flow Conceptual Diagram 
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6.2.2 Basic Instruction Pipeline 


Figure 6-3 illustrates the basic instruction pipeline timing. 
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Figure 6-3. Basic Instruction Pipeline Timing Diagram 


6.3 SEQUENCER UNIT 


The instruction sequencer is the heart of the core. It controls data flow among execution 
units and register files, implements the basic instruction pipeline, fetches instructions from 
the memory system and issues them to available execution units, and maintains a state 
history so it can back up the machine in the event of an exception. The sequencer data path 
is illustrated in Figure 6-4. In addition, the sequencer implements all branch processor 
instructions, including flow control and condition register instructions. 
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6.3.1 Flow Control 


Flow control operations, or branches disrupt normal instruction pipeline flow. A change in 
program flow creates bubbles in the pipeline because of the time it takes to fetch the newly 
targeted instruction stream. In typical code, with 4 or 5 sequential instructions between 
branches, the machine could waste up to 25% of its execution bandwidth waiting on branch 
latency. 
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Figure 6-4. Sequencer Data Path 


The sequencer maintains a 4-instruction deep instruction prefetch queue to execute 
branches in parallel with the execution of sequential instructions. Ideally, a sequential 
instruction is issued every clock, even when branches are present in the code. This is 
referred to as branch folding. The instruction prefetch queue also eliminates stalls due to 
long latency instruction fetches and all instructions are fetched into the instruction prefetch 
queue, but only sequential instructions are issued to the execution units when they reach 
the head of the queue. Branches enter the queue to mark watchpoints. See Section 20 
Development Capabilities and Interface for details. Since branches do not prevent the 
issue of sequential instructions unless they come in pairs, the performance impact of 
entering branches in the instruction prefetch queue is negligible. 
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In addition to branch folding, the core implements a branch reservation station and static 
branch prediction so branches can issue as early as possible. The reservation station allows 
a branch instruction to issue even before its condition is ready. With the branch issued and 
out of the way, instruction prefetch can continue while the branch operand is being 
computed and the condition is evaluated. Static branch prediction determines which 
instruction stream is prefetched while the branch is being resolved. When the branch 
operand becomes available, it is forwarded to the branch unit and the condition is evaluated. 


Branch instructions whose condition is unavailable and forced to issue to the reservation 
station are said to be predicted and these branches, which later turn out to have followed 
the wrong path, are said to be mispredicted. Branch instructions that issue with source data 
already available are unpredicted and those instructions fetched under a predicted branch 
are conditionally fetched. The core ignores conditionally prefetched instructions fetched 
under a mispredicted branch. 


Table 6-1. Branch Prediction Policy 


BRANCH TYPE DEFAULT PREDICTION | MODIFIED PREDICTION 
(Y=0 (Y=1) 


BC With Negative Offset Fall Through 
BC With Positive Offset Fall Through 


BCLR or BCCTR (Ik or ctr) Address Ready Fall Through 
B (Unconditional Branch) Taken Taken 


6.3.2 Issuing Instructions 





The sequencer tries to issue a sequential instruction on each clock whenever possible. 
However, for an instruction to issue, the execution unit must be available and able to discern 
whether or not the required source data is available and to ensure that no other instruction 
still in execution targets the same destination register. The sequencer informs the execution 
units of the existence of the instruction on the instruction bus. The execution units then 
decode the instruction, interrogate the register unit (if the operands and targets are free), 
and inform the sequencer that it accepts the instruction for execution. 
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6.3.3 Interrupts 


The core interrupts can be generated when an exception occurs. An exception results when 
certain instructions are executed or an asynchronous external event occurs. There are five 
exception sources in the MPC823: 


e External interrupt request 
¢ Certain memory access conditions (protection faults and bus error) 


e Internal errors, such as an attempt to execute an unimplemented opcode or 
floating-point arithmetic overflow 


e Trap instructions 
e Internal exceptions (breakpoints and debug counter’s expiration) 


Interrupt handling is transparent to user mode code and uses the same mechanism to 
handle all types of exceptions. When a user mode instruction experiences an exception, the 
machine is placed into privileged state and control is transferred to a software exception 
handler routine located at some offset within a memory-based vector table. Each interrupt 
generated in the machine transfers control to a different address in the vector table. For 
more information on initializing the base address of the vector table, refer to Table 6-6 as 
well as the PowerPC definition of the machine state register. When the exception has been 
handled, the handler can continue executing your program without ever knowing that an 
event has occurred. As specified in the PowerPC Microprocessor Family: The Programming 
Environment for 32-Bit Microprocessors, the core implements a precise interrupt model. 
This means that when an interrupt is taken, the following conditions are met: 





e No instruction that logically follows the faulting instruction in the code stream has 
started executing. 


e Allinstructions preceding the faulting instruction appear to have completed with respect 
to the executing processor. 


e The precise location (address) of the faulting instruction is known to the exception 
handler. | 


¢ The instruction causing the exception might not have started executing (before 
interrupt), could be partially completed, or has completed (after interrupt), depending on 
the interrupt and instruction types. See Table 6-2 for details. 


In any case, a partially completed instruction is restartable and can be reexecuted after the 
interrupt is handled. This precise exception model can simplify and speed up exception 
processing because the software does not have to manually save the machine’s internal 
pipeline states, unwind the pipelines, or cleanly terminate the faulting instruction stream. Nor 
does it have to reverse the process to resume execution of the faulting stream. | 
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Table 6-2. Before and After Interrupts 


INTERRUPT TYPE INSTRUCTION BEFORE / CONTENTS OF SRRO 
TYPE AFTER 


A 


System Reset Next Instruction to Execute 


Machine Check Interrupt Faulting Instruction 

Implementation pedi Instruction / Any Before Faulting Fetch or Load/Store 

Data TLB Miss / Error Interrupts | 

Other Asynchronous Interrupts Any Before Next Instruction to Execute 

(Noninstruction Related Interrupts) 

Alignment Interrupt Load / Store Faulting Instruction 

Privileged Instruction Any Privileged Before Faulting Instruction 
Instruction 








System Call Interrupt 


Debug !- Breakpoint Faulting Instruction 
Debug L- Breakpoint Load / Store Faulting Instruction + 4 


Implementation Dependent Software NA Before Faulting Instruction 
Emulation Interrupt 
Floating-Point Unavailable Floating-Point Faulting Instruction 


6.3.4 Implementing the Precise Exception Model 


To achieve maximum performance, many pieces of the instruction stream are concurrently 
processed by the core independent of the sequence specified by the executing program. 
Instructions execute in parallel and are completely random. The hardware ensures that this 
out-of-order operation never has an effect different than that specified by the program. This 
requirement is most difficult to assure when an interrupt occurs after instructions that 
logically follow the faulting instruction or have already completed. At the time of an interrupt, 
the machine state becomes visible to other processes and, therefore, must be in the 
appropriate architecturally specified condition. The core takes care of this in the hardware 
by auiomatically backing up the machine to the insiruction which caused the interrupt and 
is, therefore, said to implement a precise exception model. This is, of course, assuming that 
the instruction causing the exception has not begun when the interrupt occurs. 
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To recover from an interrupt, a history buffer is used. This buffer is a FIFO queue that 
records the relevant machine state at the time of each instruction issue. Instructions are 
placed on the tail of the queue when they are issued and percolated to the head of the queue 
while they are in execution. Instructions remain in the queue until they complete execution 
and all preceding instructions have been completed to a point where no exception can be 
generated (in the core, such a condition is fulfilled by waiting for full completion). 
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In the event of an exception, the machine state necessary to recover the architectural state 
is available. As instructions finish executing, they are released (retired) from the queue and 
the buffer storage is reclaimed for new instructions entering the queue. An exception can be 
detected at any time during instruction execution and is recorded in the history buffer when 
the instruction finishes execution. The exception is not recognized until the faulting 
instruction reaches the head of the history queue, but once the exception is recognized, an 
interrupt process begins. The queue is reversed and the machine is restored to its state at 
the time the instruction is issued. Machine state is restored at a maximum rate of two 
floating-point and two fixed-point instructions per clock. 


QUEUE QUEUE 
TAIL HEAD 






RETIRED 
INSTRUCTIONS 


ISSUED 
INSTRUCTIONS 





HISTORY BUFFER QUEUE 


COMPLETED INSTRUCTIONS 
WRITEBACK 





Figure 6-5. History Buffer Queue 


To correctly restore the architectural state, the history buffer must record the value of the 
destination before the instruction is executed. The destination of a store instruction, 
however, is in memory and it is not practical from a performance standpoint to always read 
memory before writing it. Therefore, stores issue immediately to store buffers, but do not 
update memory until all previous instructions have finished executing without exception or 
the store has reached the head of the history buffer. 


The history buffer has enough storage to hold the state of six instructions, but no more than 
four fixed-point instructions. The other two instructions can be condition code or branch | 
instructions. In the event of a long latency instruction, it is possible that issued instructions 
will fill the history buffer. If so, instruction issue waits until the long latency operation finishes. 
The following types of instructions can potentially cause the history buffer to fill: 


e Floating-point arithmetic instructions 
e Integer divide instructions 
¢ Instructions that affect or use resources external to the core (load/store instructions) 
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6.3.4.1 RESTARTABILITY AFTER AN INTERRUPT 


Most of the interrupt cases in the core are always restartable. Some nicnuge may be 
unable to be restarted because they can be recognized when the machine status 
save/restore 0 and 1 registers (SRRO and SRR1) are busy. Such interrupts in the PowerPC 
architecture are known as system reset and machine check. 


All other interrupt types defined in the architecture should always be restartable. By 
convention, no interrupt generating instruction should be executed between the start of an 
interrupt handler and the save of the registers altered by any interrupt or between restore of 
these registers and the execution of the rfi instruction. These registers being the SRRO and 
SRR1 registers or the data address register (DAR) and data storage interrupt status register 
(DSISR) for some interrupt types. 


External interrupts are also masked in these areas. In the core, two implementation-specific 
interrupt types can have this characteristic—debug port unmaskable interrupt and 
breakpoint interrupt in nonmaskable mode. Since there might be a situation in which it is 
preferable to be restartable, such as in the mentioned implementation-specific interrupts, a 
mechanism is defined to notify the interrupt handler code whether it is in a restartable state. 


The mechanism uses a bit within the machine state register (MSR) called the recoverable 
interrupt bit (MSR,p). The MSR», shadow bit in the SRR1 register indicates if the interrupt is 
restartable or not. This bit does not need to be checked on interrupt types that are 
restartable by convention, except those previously mentioned. The MSR, bit follows a 
similar behavior as the external interrupt enable bit (MSR_--). Every time an interrupt occurs, 
MSRp, is copied to its shadow in the SRR1 register (like the MSR) and cleared. Every time 
an rfi instruction is executed, MSRa, is copied from its shadow in the SRR1 register. In 
addition, it can be altered by the software via the mtmsr instruction. The MSRap, bit is 
intended to be set by the interrupt handler software after saving the machine state, (registers 
SRRO, SRR1, DAR, and DSISR if needed) and cleared by the interrupt handler software 
before euigung the machine state. 


In critical code sections where MSRe_¢ is negated but the SRRO and SRRi1 registers are not 
busy, MSRp, should be left asserted. In these cases, if an interrupt occurs it is restartable. 
To facilitate the software manipulation of the MSR, and MSRe, bits, the core includes 
special commands implemented as move to special register. The following table defines 
these special register mnemonics. A write of any data to these locations performs the 

| operation specified in the following table. Any read from these locations is treated like any 
other unimplemented instruction and, therefore, results in an implementation- dependent 
software emulation interrupt. — 
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Table 6-3. Special Ports to Machine State Register Bits 


External Interrupt Enable: 
End of Interrupt Handler's Prologue, Enable Nested 
External Interrupts; 


End of Critical Code Segment in Which External 
Interrupts 
Were Disabled 
















External Interrupt Disable, But Other Interrupts Are Recoverable: 
End of Interrupt Handler's Prologue, Keep External 
Nested Interrupts Disabled; 
Start of Critical Code Segment in Which External 
Interrupts Are Disabled 


NRI 82 Nonrecoverable Interrupt: 
Start of Interrupt Handler’s Epilogue 


6.3.5 Processing an Interrupt 





The following table provides the significant events that occur when processing an interrupt. 


Table 6-4. Interrupt Latency 


TIME POINT FETCH ee ea INSTRUCTION COMPLETE | KILL PIPELINE 


Instruction Complete 
and All Previous 
Instructions Complete 
Start Fetch 
Handler 
Kill Pipeline 
D <B +3 Clocks ae); ae 


First Instruction of 
Handler Issued 


NOTES: 1. At time point A an instruction that will cause an interrupt is issued. 

















2. Attime point B the excepting instruction has reached the head of the history queue, thus implying that 
all instructions preceding it in the code stream have finished execution without generating any interrupt. 
Also, the excepting instruction itself has completed execution. At this time the exception is “recognized” 
and exception processing begins. If, at this point, the instruction had not generated an exception, it 
would have been retired. 


3. At time point C the sequencer starts to fetch the interrupt handler’s first instruction. 


By time point D the state of the machine prior to the issue of the excepting instruction is restored (the 
’ machine is restored to its state at time. 


5. Attime point E the machine state register and instruction pointer of the executing process have been 
saved and control has been transferred to the interrupt handler routine. 
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At time point A the excepting instruction issues and begins executing. During the interval 
between A and B, previously issued instructions are finishing execution. This interval is 
equivalent to the time required for all instructions currently in progress to complete. At time 
point B, the exception is recognized and during the interval between B and D the machine 
state is being restored. This time is a maximum of 10 cycles. At time point C, the core starts 
fetching the first instruction of the exception handler if the interrupt handler is external. It is 
5 cycles if it is in the instruction cache and NO SHOW mode is on. 


At time point D all state has been restored and during the interval between D and E, the 
machine is saving context information in the SRRO and SRR1 registers, disabling interrupts, 
placing the machine in privileged mode, and continues the process of fetching the first 
instructions of the interrupt handler from the vector table. The interval between D and E 
requires a minimum of one clock. The interval between C and E depends on the memory 
system and is the time it takes to fetch the first instruction of the interrupt handler. For full 
history buffer restore time, it is no less then two clocks. 


6.3.6 Serialization 


The core has multiple execution units, each of which can be executing different instructions 
at the same time. This is normally transparent to your program, but in some special 
circumstances (debugging, !/O control, multiprocessor synchronization) it might become 
necessary to force the machine to serialize. There are two possible serialization actions 
defined for the core: | 


¢ Execution serialization—Instruction issue is halted until all instructions currently in 
progress have completed execution, all internal pipeline stages and instruction buffers 
have emptied, and all outstanding memory transactions are completed. 


e Fetch serialization—lInstruction fetch is halted until all instructions currently in the 
processor have completed execution. After fetch serialization, the machine is 
- completely synchronized. . 


An attempt to issue a serializing instruction causes the machine to serialize before the 
instruction issues. Only the sync instruction guarantees serialization across PowerPC 
implementations. Fetching an isync instruction causes fetch serialization. Also, when the 
serialize mode bit (CTRLgep) is asserted or is in debug mode, any instruction can cause 
fetch serialization. 


6.3.6.1 LATENCY > 


The time required to serialize the machine is also the amount of time needed to complete 

the instructions currently in progress. This time is heavily dependent on the instructions in 
progress and the memory system latency. It is impossible to put an absolute upper bound 
on this time because the memory system design is not under the core’s control. The time to 
complete the current instruction is generally the machine serialization time and the specific 
instruction execution time determines how long serialization takes. This can be either divide, 
load, or store a multiple, string, or pair of simple load/store instructions. 
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6.3.7 The External Interrupt 


The core provides one external interrupt line: the architectural maskable external interrupt. 
In the MPC823, this interrupt is generated by the on-chip interrupt controller. It is software 
acknowledged and maskable by the MSRe¢ bit, which is automatically cleared by the 
hardware to disable external interrupts when any interrupt is taken. 


6.3.7.1 LATENCY 


When an external interrupt is detected, every instruction that can retire from the history 
buffer does so and the interrupt is assigned to the instruction at the head of the history buffer 
(at point B in Table 6-4). However, the following conditions must be met before the 
instruction at the head of the queue can retire. 


e The instruction must be completed without exception 


e The instruction must either be a mtspr, mtmsr, or rfi instruction, a memory reference, 
or a storage or cache control instruction. 


Any instruction that does not meet these criteria is discarded with all of its side effects and 
the execution at the end of the interrupt handler resumes with the first instruction that was 
discarded. If all the instructions in the history buffer were allowed to complete, execution at 
the end of the interrupt handler resumes with the next instruction. External interrupt latency 
depends on the time required to reference memory. The measurement is equal to the time 
taken for one of the following three possible events, in addition to the interval from B to E as 
shown in Table 6-4. 





Longest load/store multiple/string instruction used 
or | 

One bus cycle for aligned access 

or 

Two bus cycles for unaligned access 


Actual system-level interrupt latency can be worse than just the interval from B to E. If the 
instruction prior to the one in which the interrupt was assigned generates an exception, then 
the exception is recognized first. If minimal interrupt latency is an important system | 
parameter, interrupt handlers should save the machine context and reenable external 
interrupt as rapidly as possible so that a pending external interrupt receives service quickly. 
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6.3.8 Interrupt Ordering 


There are two main types of interrupts: 


* Instruction-related interrupts 
e Asynchronous interrupts 


Instruction-related exceptions (interrupt causes) are detected while the instruction is in 
various stages of being processed by the core. Exceptions found early in instruction 
processing preclude detection of further exceptions. This earlier interrupt will eventually be 
taken. If more.than one instruction in the pipeline causes an exception, only the first 
exception is taken and causes an interrupt. The remaining instruction-induced exceptions 
are ignored. The following table lists the instruction-related interrupts in the order of 
detection within the instruction processing. 


Table 6-5. Instruction-Related Interrupt Detection Order 


plemeataten Dependent Instruction TLB Instruction Memory Management Unit TLB Miss 
iss 

E 

| 









Implementation Dependent Instruction TLB Instruction Memory Management Unit 
rror Protection / Translation Error 
= a Machine Check Interrupt Fetch Error 
ae Debug I- Breakpoint Match Detection ? . 
Floating-Point Unavailable Attempt to is Made to Execute Floating-Point 
Instruction and MSRrp =0 | 
72 Privileged Instruction Attempt to Execute Privileged Instruction in 
Problem Mode 








_ | Alignment Interrupt Load/Store Checking | 
System Call Interrupt SC Instruction 7 





FB Implementation Dependent Data TLB Miss Data Memory Management Unit TLB Miss 


| ae 
4 
1 
Implementation Dependent Data TLB Error Data Memory Management Unit TLB Protection/ 
| Translation Error 
Machine Check Interrupt Load or Store Access Error 


Debug L- Breakpoint | Match Detection 


NOTES: 1. The trace mechanism is implemented by letting one instruction go as if no trace is enabled and 
trapping the second instruction. This, of course, refers to this second instruction. 


prementaton Dependent Software Emulation | Attempt to Invoke Unimplemented Feature 
nterrup 





2. Exclusive for any one instruction. 
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More than one asynchronous interrupt cause or exception can be present at any time. 
However, when more than one interrupt causes exist, only the highest priority interrupt is 
taken, as shown in the following table. 


Table 6-6. Interrupt Priority Mapping 


Twoween [| wrenmorrnee ASE 
1 [Personen Por tearasiabe narant [Saal Fonte Dopmen Pon 
— 
me 










Peripheral Breakpoint Request or Breakpoint Signal From Any Peripheral 
Development Port Maskable Interrupt 

External Interrupt Signal From the Interrupt Controller 
Decrementer Interrupt Decrementer Request 


6.4 THE REGISTER UNIT 


The fixed-point registers bank holds thirty-two 32-bit fixed-point registers and some control 
registers. The register unit holds the general register files of the core and performs the 
following operations: 





e Decodes the operand fields of all sequential instructions 

e Drives the operand buses, as requested by the execution unit 
¢ Performs scoreboard checking and signing 

¢ Samples the resulting data from the writeback bus 
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6.4.1 Control Registers 


The following tables describe the core control registers, also known as special-purpose 
registers, implemented within the MPC823. 


ana: 6-7. Standard Special-Purpose Registers 


REGISTER PRIVILEGED 
NAME 
totus 
Read: Sync Relative to Load/ 
Store Operations 


00000 10010 DSISR Full Sync 
Sync Relative to Load/ 
_ at 


=p Store Operations 






SERIALIZE ACCESS 














Write: Full Sync 














Full Syne 


Read: Sync Relative to Load/ 
Store Operations 


[e100 [ae [vn 


aaeuaeee— See 6-8. Standard Timebase Register Mapping 


REGISTER PRIVILEGED 
NAME 


a 
i 
[ae [om [0 rece [vee [Wee 
as [em [0 uma [vee | waren 


NOTES: 1. Extended opcode for mftb, 371 rather then 339. 
2. Any write (mtspr) to this address results in an implementation-dependent software emulation interrupt. 


NO Nh he) N N 
No Nh NO = i 















SERIALIZE ACCESS 





3. Any read (mftb) to this address results in an implementation-dependent software emulation interrupt. 
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aa ae: 6-9. Additional Special-Purpose Registers 


REGISTER PRIVILEGED SERIALIZE ACCESS 
NAME 


00100 11000 CMPE Debug Fetch Sync 
Synch Relative 
to Load/Store 
Operations 

00100 11001 CMPF Debug 

00100 11010 CMPG Debug 

00100 11011 CMPH Debug 

00100 11100 LCTRL1 Debug 
to Load/Store 
Operations 

00100 11101 LCTRL2 Debug ite: Fetch Sync 

: Synch Relative 
to Load/Store 
Operations 


00100 11110 ICTRL Fetch Sync on Write 


00100 11111 one Write: Fetch Sync 
Read: Synch Relative 
to Load/Store 
Operations 


| 40011 | = 10110 DPDR | Debug | Read and Write 





Fetch Sync 
Synch Relative 
to Load/Store 
Operations 


Fetch Sync 
Synch Relative 
to Load/Store 
Operations 


Fetch Sync 
Synch Relative 
to Load/Store 
Operations 


Fetch Sync 
Synch Relative 
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Table 6-9. Additional Special-Purpose Registers (Continued) 


REGISTER PRIVILEGED 
NAME 
638 


10001 11000 DC_CST Eves: =| Write - As a Store 



























SERIALIZE ACCESS 





Write - As a Store 
Write - As a Store 





Write - As a Store 























10001 11010 DC_DAT Write - As a Store 
11000 10000 MI_CTR Write - As a Store 
11000 10010 MI_AP Write - As a Store 


| 11000 10011 MI_EPN Wtite - As a Store 


Yes 
Yes 
Yes 
Yes 
Yes 
(MI_L1DL2P) 


Write - As a Store 


Write - As a Store 


11000 11001 M_CASID Write - As a Store 
11000 - 11010 MD_AP Write - As a Store 
11000 11011 | MD_EPN | Write - As a Store 


796 ~ 11000 — 11100 M_TWB Write - As a Store 
(MD_L1P) 
797 11000 11101 MD_TWC Write - As a Store 
| | (MD_L1DL2P) 


11000 11110 Write - As a Store 


799 11000 11111 M_TW Write - As a Store 
| (M_SAVE) 


NOTES: 1. See Section 6.3.4.1 Restartability After An Interrupt. 
2. Refer to Section 20.6.2 Development Port Registers. 


Write - As a Store 





3. Protection of registers with “debug” privileges is described in Section 20.6.1 Protecting the 
Development Port Registers. 


4. This register is a fetch-only register. Using mtspr is ignored and using mfspr gives an undefined value. 
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Table 6-10. Other Control Registers 


DESCRIPTION | NAME COMMENTS PRIVILEGED SERIALIZE ACCESS 


6.4.1.1 PHYSICAL LOCATION OF SPECIAL REGISTERS 


Some of the special registers in the core are physically located outside of the core. Access 
to these registers is gained the same way as any other special register—via the appropriate 
mitspr, mfspr instructions through the internal chip buses. Apart from the PowerPC 
timebase counter and decrementer, in the current implementation the following encoding is 
reserved for special registers not located within the core. 







Table 6-11. Encoding Special Registers Located Outside the Core 


eens | eh 
[0001 [som fost cacnereoses —SSCSCSC~C~“~*~* 


For these registers, a bus cycle is performed on the internal bus with the following address. 


If any address error occurs on this cycle, an implementation-dependent software emulation 
interrupt is taken. | 







RESERVED FOR 
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6.4.1.2 PowERPC STANDARD CONTROL REGISTER BIT ASSIGNMENT 


6.4.1.2.1 Machine State Register. The 32-bit machine state register (MSR) defines the 
state of the processor. It can be read by the mfmsr instruction. However, it can be modified 
by the mtmsr, sc, and rfi instructions, as well as the hard reset configuration word. Refer to 
Section 4.3.1.1 Hard Reset Configuration Word for more information. 


MSR 





NOTE: — = Undefined. 


Bits O—12—Reserved 


These bits are reserved and should be set to O. Bits 0, 5, and 9 are loaded from the 
corresponding bit in the MSR when an interrupt is taken. The appropriate bit in the MSR is 
loaded from this bit when an rfi is executed. Reserved bits in the MSR are set from the 
source value on write and return the value last set for it on read. 


POW—Power Management Disable 


When this bit is clear it allows you to automatically switch between low and high frequency 
operation or between normal low mode and normal high mode. When this bit is set, power 
management is disabled. Refer to Section 5 Clocks and Power Control for more 
information on bus power management. 


Bit 14—Reserved 
This bit is reserved and should be set to 0. 


iLE—Interrupt Little-Endian Mode 


When an exception occurs, this bit is copied into the MSR to select the endian mode for the 
context established by the exception. 


0 = Little-endian mode is selected. 
1 = Big-endian mode is selected. 


EE—External Interrupt Enable 


This bit is loaded from the corresponding bit in the MSR when an interrupt is iaven. The 
appropriate bit in the MSR is loaded from this bit when an rfi is executed. 
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PR—Problem State 


This bit is loaded from the corresponding bit in the MSR when an interrupt is taken. The 
appropriate bit in the MSR is loaded from this bit when an rfi is executed. 


FP—Floating-Point Available 


This bit is loaded from the corresponding bit in the MSR when an interrupt is taken. The 
appropriate bit in the MSR is loaded from this bit when an rfi is executed. 


ME—Machine Check Enable 


This bit is loaded from the corresponding bit in the MSR when an interrupt is taken. The 
appropriate bit in the MSR is loaded from this bit when an rfi is executed. 


FEQ—Floating-Point Exception Mode 0 


This bit is loaded from the corresponding bit in the MSR when an interrupt is taken. The 
appropriate bit in the MSR is loaded from this bit when an rfi is executed. 


SE—Single-Step Trace Enable 


This bit is loaded from the corresponding bit in the MSR when an interrupt is taken. The 
appropriate bit in the MSR is loaded from this bit when an rfi is executed. 


BE—Branch Trace Enable 


This bit is loaded from the corresponding bit in the MSR when an interrupt is taken. The 
appropriate bit in the MSR is loaded from this bit when an rfi is executed. 





FE1—Floating-Point Exception Mode 1 


This bit is loaded from the corresponding bit in the MSR when an interrupt is taken. The 
appropriate bit in the MSR is loaded from this bit when an rfi is executed. 


Bit 24—Reserved 


This bit is reserved and should be set to 0. It is loaded from the corresponding bit in the MSR 
when an interrupt is taken. The appropriate bit in the MSR is loaded from this bit when an 
rfi is executed. Reserved bits in the MSR are set from the source value on write and return 
the value last set for it on read. 


|P—Interrupt Prefix 


This bit is loaded from the corresponding bit in the MSR when an interrupt is taken. The reset 
value of this bit is determined by the hard reset configuration word. For more information, 
see Section 4.3.1.1 Hard Reset Configuration Word. 


O= The interrupt prefix is OxO0On_nnnn. 
1 = The interrupt prefix is OXxFFFn_nnnn. 


IR—Instruction Relocate 


This bit is loaded from the corresponding bit in the MSR when an interrupt is taken. The 
appropriate bit in the MSR is loaded from this bit when an rfi is executed. 
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DR—Data Relocate 


This bit is loaded from the corresponding bit in the MSR when an interrupt is taken. The 
appropriate bit in the MSR is loaded from this bit when an rfi is executed. 


Bits 28 and 29—Reserved 


These bits are reserved and should be set to 0. Reserved bits in the MSR are set from the 
source value on write and return the value last set for it on read. 


Rl—Recoverable Interrupt 
This bit is loaded from the corresponding bit in the MSR when an interrupt is taken. The 


appropriate bit in the MSR is loaded from this bit when an rfi is executed. 


LE—Little-Endian Mode 


This bit is loaded from the corresponding bit in the MSR when an interrupt is taken. The 
appropriate bit in the MSR is loaded from this bit when an rfi is executed. This bit is loaded 
from the ILE bit when an interrupt is taken 


6.4.1.2.2 The Condition Register. The condition register (CR) contains eight 4-bit 
condition fields. Each field can have one of the following formats and the software can 
assign an arbitrary meaning to them. 

e Bit O—Negative (LT). The result is negative. 

e Bit i—Positive (GT). The result is positive. - 

e Bit 2—Zero (EQ). The result is zero. 

e Bit 3—Summary Overflow (SO). The values of this bit is copied from XERgo. 
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6.4.1.2.3 Fixed-Point Exception Cause Register. The following table provides the bit 
assignments for the fixed-point exception cause register (XER). The bits are based on the 
final result produced by executing an instruction. 


RESERVED 





SO—Summary Overflow 


This bit is set when an instruction other than mtspr sets the OV bit. Once it is set, it stays 
that way until an mtspr or merxr instruction clears it. It is not altered by compare instructions 
or other instructions that cannot overflow. SO is cleared and OV is set when an mtspr 
instruction is executed, which supplies the zero values for these bits. 


OV—Overflow 


When this bit is set it indicates that an overflow has occurred during the execution of an 
instruction. The add, subtract, and negate instructions with OE equal to 1, set this bit if the 
carry out of the MSB is not equal to that carry out of the MSB+1. The multiply low and divide 
instructions with OE equal to 1, set this bit if the result cannot be represented in 64 bits 
(mulld, divd, divdu) or 32 bits (mullw, divw, divwu). The OV bit is not altered by compare 
instructions that cannot overflow, except mtspr to the XER and merxr. 


CA—Carry 


This bit is set during execution of the following instructions. It is not altered by compare 
instructions or by other instructions that cannot carry, except shift right algebraic, mtspr to 
the XER, and merxr. 


e Add carrying, subtract from carrying, add extended, and subtract from extended 
instructions set CA if there is a carry out of the MSB. Otherwise, it is cleared. 

e —_ The shift right algebraic instructions set CA if any 1 bits have been shifted out of a 
negative operand. Otherwise, it is cleared. 


Bits 3-24—Reserved 
These bits are reserved and should be set to 0. 


BCNT—Byte Count for Load/Store String Operations 
This field specifies the number of bytes to be transferred by a Iswx or stswx instruction. 
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6.4.1.3 INITIALIZING THE CONTROL REGISTERS 


6.4.1.3.1 System Reset Interrupt. A system reset interrupt occurs when the IRQO pin is 
asserted. The only control registers affected by the system reset interrupt are the MSR, 
SRRO, and SRA registers. For information on the values of these registers, refer to 
Section 7.3.7.3.1 System Reset Interrupt. 


6.4.1.3.2 Hard/Soft Reset. When a hard or soft reset occurs, the registers affected by 
system reset are set in the same way. The following list shows how each register is set. 

e SRRO, SRR1i—Set to an undefined value. 

e MSR,p—Programmable. 

e MSRye—Set to zero. 

e ICTRL—Set to 0. 

e LCTRL1—Set to 0. 

e LCTRL2—Set to 0. 

¢ COUNTA¢.3;—Set to 0. 

¢ COUNTB,¢.3;—Set to 0. 

e |CR—Set to 0 (no interrupt occurred). 

¢ DER=p 14.28.31—Set to 1 (all debug-specific interrupts cause debug mode entry). 


6.5 THE FIXED-POINT UNIT 


The fixed-point unit implements all fixed-point processor instructions, except the fixed-point 
storage access instructions that are implemented by the load/store unit. Refer to the 
PowerPC Microprocessor Family: The Programming Environment for 32-Bit 
Microprocessors manual for more information. 


6.5.1 XER Update In Divide Instructions 


The divide instructions have a relatively long latency, but those instructions can update the 
OV bit in the XER after one cycle. Therefore, data dependency on the XER is limited to one 
cycle, although the divide instruction latency can be a maximum of 11 clocks. 
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6.6 THE LOAD/STORE UNIT 


The load/store unit handles all data transfers between the register file and chip internal bus. 
It is implemented as an independent execution unit so that stalls in the memory pipeline do 
not cause the master instruction pipeline to stall, unless there is a data dependency. The 
unit is fully pipelined so that memory instructions of any size can be issued on back-to-back 
cycles. 


There is a 32-bit wide data path between the load/store unit and fixed-point register file. 
Single-word accesses to the internal on-chip data RAM require one clock, resulting in two 
clock latencies and double-word accesses require two clocks, which results in three clock 
latencies. Because the internal bus is 32 bits wide, double-word transfers take two bus 
accesses. The load/store unit implements all of the PowerPC load/store instructions in 
hardware, including unaligned and string accesses. 


The following is a list of the load/store unit’s main features: 


e Supports many instructions 

e Two-entry load/store instruction address queue 

e Pipelined operation 

e Minimal load latency—2 clocks using 1 clock on-chip data RAM 


e Minimal store latency—1 clock since the load/store unit ends the store execution in 
2 clocks, using 1 clock on-chip data RAM. 


e Load/store multiple and string instructions synchronize 
¢ Load/store breakpoint/watchpoint detection support 
Figure 6-6 illustrates a conceptual block diagram of the load/store unit and its two queues. 


The address queue is a 2-entry queue shared by all load/store instructions and the 
fixed-point data queue is a 2-entry, 32-bit wide queue that holds fixed-point data. 


The load/store unit has a dedicated writeback bus so that loaded data received from the 
internal bus is written directly back to the fixed- or floating-point register files. 
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FIXED-POINT FIXED-POINT 
UNIT REGISTERS FILE 


ADDRESS FIXED-POINT 
QUEUE 39 DATA 


AND QUEUE 
INCREMENT 


LOAD / STORE UNIT 





D-CACHE / D-MMU 
INTERFACE 


Figure 6-6. Load/Store Unit Functional Block Diagram 


To execute multiple (Imw, stmw) instructions, string instructions, unaligned accesses, and 
double-precision floating-point load/store instructions, the load/store unit contains an 
address incrementor that generates the needed addresses. This allows the unit to execute 
the unaligned accesses without stalling the master instruction pipeline. 


6.6.1 Issuing Load/Store Instructions 


When load or store instructions are encountered, the load/store unit checks the scoreboard 
to determine if all of the operands are available. These operands include: 


e Address register operands 

e Source data register operands (for store instructions) 

e Destination data register operands (for load instructions) 

e Destination address register operands (for load/store with update instructions) 
If all operands are available, the load/store unit takes the instruction and enables the 
sequencer to issue a new instruction. Then, using a dedicated interface, the load/store unit 


notifies the integer unit of the need to calculate the effective address. All load/store 
instructions are executed and terminated in order. 
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lf there are no prior instructions waiting in the address queue, the load/store instruction is 
issued to the data cache immediately at the time the instruction is taken. Otherwise, if there 
are prior instructions remaining whose addresses have not yet been issued to the data 
cache, the instruction is inserted into the address queue and data is inserted into the 
respective store data queue. For load/store with update instructions, the destination address 
register is written back on the following clock, regardless of the address queue’s state. 


6.6.2 Serializing Load/Store Instructions 
The following load/store instructions are not taken until all previous instructions have 
terminated. 

e Load/store multiple instructions—Imw, stmw 

e Storage synchronization instructions—Iwarx, stwcex, sync 


e String instructions—Iswi, Iswx, stswi, stswx 
e Move to internal special registers and move to off-core special registers 


The following load/store instructions must terminate before more instructions can be issued. 


e Load/store multiple instructions—Imw, stmw 
° Storage synchronization instructions—Iwarx, stwcx, sync 
e String instructions—Iswi, Iswx, stswi, stswx 





6.6.3 Instructions Issued to the Data Cache 


The load/store unit pipelines load accesses. The individual cache cycles of all multiregister 
instructions and unaligned accesses are pipelined into the data cache interface. 


6.6.4 Issuing Store Instruction Cycles 


A new store instruction is not issued to the data cache until all prior instructions have 
terminated without an exception because the core supports the precise interrupt model. If a 
load instruction is followed by a store instruction, a one clock delay is inserted between the 
load bus cycle termination and the store cycle issue. 


6.6.5 Issuing Nonspeculative Load Instructions 


Load instructions targeted at a nonspeculative memory region are identified as 
nonspeculative one clock cycle after the previous load/store bus cycle termination, but only 
if all prior instructions have terminated normally and without an exception. The 
nonspeculative identification relates to the state of the cycle’s associated instruction. For 
Imw, although the cycles are pipelined into the bus, they are all marked as nonspeculative 
because the instruction is nonspeculative. 





With a single register load instruction where more than one bus cycle is generated, some of 
the cycles can be marked as speculative and later cycles can be marked as nonspeculative 
afier all prior instructions terminate. When executing speculative load cycles to the 
nonspeculative external memory region, no external cycles are generated until the load 
instruction becomes nonspeculative. 
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6.6.6 Executing Unaligned Instructions 


The load/store unit supports fixed-point unaligned accesses in the hardware. The 32-bit 
L-bus only supports naturally aligned transfers. For an unaligned instruction, the load/store 
unit breaks the instruction into a series of aligned transfers that are pipelined into the bus. 
Figure 6-7 illustrates the number of bus cycles needed to execute unaligned instructions. 







00’h 
04’h 


1 BUS CYCLE 


00’h 
04’h 


1 BUS CYCLE 


00’h 
04’h 


1 BUS CYCLE 


00’h 2 BUS CYCLES 





Figure 6-7. Number of Bus Cycles Needed For Unaligned, 
Single Register Fixed-Point Load/Store Instructions 
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6.6.7 Little-Endian Mode Support 


The load/store unit implements the little-endian mode as it is specified by the PowerPC 
architecture and in this mode the modified address is issued to the data cache. For an 
individual scalar unaligned transfer or an attempted execution of a multiple/string instruction, 
an alignment exception is generated. 


6.6.8 Atomic Update Primitives 


The lwarx and stwex instructions are atomic update primitives. Storage reservation 
accesses made by the same processor are implemented by the load/store unit. The external 
bus interface module implements storage reservation as it relates to accesses made by 
external bus masters. Accesses made by other internal masters to internal memories 
implements storage reservation as it relates to special internal bus snoop logic. ns logic is 
implemented in the data cache. 


When a Iwarx instruction is executed the load/store unit issues a cycle to the data cache 
with a special attribute. For an external memory access, this attribute causes the external 
bus interface module to set a storage reservation on the cycle address. The external bus 
interface module is then responsible for snooping the external bus or getting an indication 
from external snoop logic if the storage reservation is broken by some other processor 
accessing the same location. When an stwex instruction to external memory is executed, 
the external bus interface module checks to see if a reservation was lost. If loss of 
reservation has occurred, the cycle is blocked from going to the external bus and the 
external bus interface module notifies the load/store unit of a stwex failure. 


The MPC823 storage reservation supplies hooks for the support of storage reservation 
implementation in a hierarchical bus structure. For a full description of the storage 
reservation mechanism, refer to Section 7 PowerPC Architecture Compliance. In case 
of storage reservation on internal memory, a lwarx indication causes the on-chip snoop 
logic to latch the address. This logic notifies the load/store unit in the case of an internal 
master store access, then the reservation is reset. If a new Iwarx instruction address phase 
is successfully executed it replaces any previous storage reservation address at the 
appropriate snoop logic. However, when an stwex instruction is executed, the storage 
reservation is canceled, unless an alignment interrupt condition is detected. 
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6.6.9 Instruction Timing 


The following table summarizes the different load/store instructions timing in the case of 
zero wait state memory references on a parked bus. With external memory accesses, 
pipelined external accesses are assumed. 7 op? 


Table 6-12. Load/Store Instructions Timing | 
LATENCY CLEARED FROM — , 
| LOAD/STORE UNIT | 
INSTRUCTION TYPE 
| i DATA CACHE EXTERNAL DATA EXTERNAL 
ae MEMORY CACHE MEMORY 
Fixed-Point Single Target 3 ~ 2 Clocks 5 Clocks 2 Clocks 5 Clocks 
Register Load (Aligned) 3 | 
Fixed-Point Single Target 1 Clock 1 Clock 2 Clocks 5 Clocks 
Register Store (Aligned) | | 
Load/Store Multiple  1+N 1+N | N+4 


NOTE: N denotes the number of registers transferred. 











String instructions are broken into a series of aligned bus accesses. Figure 6-8 illustrates 
the maximum number of bus cycles needed for string instruction execution. 


2 BUS CYCLES 


WORD - 
TRANSFERS 


3 BUS CYCLES 





2 BUS CYCLES 





Figure 6-8. Number of Bus Cycles Needed For String Instruction Execution 


6.6.10 Stalling Storage Control Instructions 
A storage control instruction waits one clock before it is taken. 


6.6.11 Accessing Off-Core Special Registers 


Access to special registers—mtspr and mfspr—implemented off-core is executed by the 
load/store unit via the internal bus using a special cycle. Refer to Section 6.4.1.1 Physical 
Location of Special Registers for detailed information. If the access terminates in a bus 
error, then an implementation-dependent software emulation interrupt is taken. All write 
operations to off-core special registers (mtspr) are previously synchronized. In other words, 
the instruction is not taken until all prior instructions terminate. 
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6.6.12 Storage Control Instructions 


Cache management instructions and lookaside buffer management instructions are 
implemented by the load/store unit. These instructions are implemented as the special bus 
write cycles, which are issued to the data cache interface. 


6.6.13 Exceptions 


6.6.13.1 DAR, DSISR, AND BAR OPERATION. The load/store unit keeps track of all 
instructions and bus cycles. When a bus error occurs, the data address register (DAR) is 
loaded with the cycle’s effective address. For a multicycle instruction, the effective address 
of the first offending cycle is loaded. 


The data storage interrupt status register (DSISR) notifies the error when an exception 
caused by the load/store occurs. For a memory management unit error, this register is 
loaded with the error status delivered by the memory management unit. For other 
exceptions, the DSISR is loaded with the instruction information as defined by the PowerPC 
architecture for alignment exception. The breakpoint address register (BAR) notifies the 
address on which an L-bus breakpoint occurred. For a multicycle instruction, the BAR 
contains the address of the first cycle with which the breakpoint condition was associated. 
The BAR has a valid value only when a data breakpoint interrupt is taken. At any other time, 
its value is boundedly undefined. The following situations cause the DAR, BAR, and DSISR 
registers to be updated. 





Table 6-13. Value Summary of the DAR, BAR, and DSISR Registers 


INTERRUPT TYPE DAR VALUE DSISR VALUE BAR VALUE 


i. 
Machine Check Interrupt Undefined 


nelementaton Dependent Software Emulation | Does Not Change Does Not Change Undefined 
nterrup 
Floating-Point Unavailable Interrupt Does Not Change Does Not Change Undefined 


Program Interrupt Does Not Change Does Not Change Does Not Change 
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SECTION 7 
POWERPC ARCHITECTURE COMPLIANCE 


This section describes implementation-dependent choices made for the core on issues that 
are optional on the PowerPC™ architecture as defined in the PowerPC Architecture Books 
I, Il, and Ill. \t also describes features that exist in the architecture, but are not supported by 
the core. The information in this section is based on the PowerPC books, but you can also 
refer to the PowerPC Microprocessor Family: The Programming Environment for 32-Bit 
Microprocessors (MPCFPE32B/AD) manual for more information. 


7.1 POWERPC USER INSTRUCTION SET ARCHITECTURE (BOOK I) 


7.1.1 Computation Modes 


The core is a 32-bit fixed-point implementation of the PowerPC architecture. Any reference 
in the PowerPC Architecture Books I, II, and Ill regarding 64-bit implementations are not 
supported by this core. No floating point of the architecture is implemented. 


7.1.2 Reserved Fields 


Reserved fields in instructions are described under the specific instruction definition 
sections. Unless otherwise stated in the specific instruction description, fields marked 

|, Il, and Ill in the instruction are discarded by the core decoding. Thus, this type of invalid 
form instructions yield results of the defined instructions with the appropriate field zero. In 
most cases, the reserved fields in registers are ignored on write and return zeros for them 
on read for any control register implemented by the core. Exceptions to this rule are bits 
16-23 of the fixed-point exception cause register (XER) and the reserved bits of the machine 
state register (MSR), which are set by the source value on write and return the value last set 
for it on read. 


7.1.3 Classes of Instructions 


Nonoptional instructions (except floating-point load, store, and compute instructions) are 
implemented by the hardware. Optional instructions are executed by 
implementation-dependent code and any attempt to execute one of these commands 
causes the core to take the implementation-dependent software emulation interrupt (offset 
x’01000’ of the vector table). Illegal and reserved instruction class instructions are supported 
by implementation-dependent code and, thus the core hardware generates the 
implementation-dependent software emulation interrupt. How the core treats invalid and 
preferred instruction forms is described in the specific processor compliance sections. 
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PowerPC Architecture Compliance 


7.1.4 Exceptions 


Invocation of the system software for any exception caused by an instruction in the core is 
precise, regardless of the type and setting. 


7.1.5 The Branch Processor 


7.1.6 Fetching Instructions 


The core fetches a number of instructions into its internal buffer (the instruction prefetch 
queue) prior to execution. If a program modifies the instructions it intends to execute, it 
should call a system library program to ensure that the modifications are visible to the 
instruction fetching mechanism prior to executing the modified instructions. 


7.1.7 Branch Instructions 


The core implements all the instructions defined for the branch processor by the PowerPC 
User Instruction Set Architecture (Book I) in the hardware. For details about the performance 
of various instructions, see Table 8-1 of this manual. 


7.1.7.1 INVALID BRANCH INSTRUCTION FORMS. Bits marked with z in the BO 
encoding definition are discarded by the core decoding. Thus, these types of invalid form 
instructions yield results of the defined instructions with the z bit zero. If the decrement and 
test CTR option is specified for the bcctr or bectrl instructions, the target address of the 
branch is the new value of the CTR. Condition is evaluated correctly, including the value of 
the counter after decrement. 


7.1.7.2 BRANCH PREDICTION. The core uses the y bit to predict path for prefetch. 
Prediction is only done for not-ready branch conditions. No prediction is done for branches 
to the link or count register if the target address is not ready (see Table 6-1 for more details). 


7.1.8 The Fixed-Point Processor 


The core implements the following fixed-point instructions: 


e Arithmetic instructions 

e Compare instructions 

e Trap instructions 

e Logical instructions 

e Rotate and shift instructions 

e Move to/from system register instructions 


All hardware instructions are defined for the fixed-point processor in the PowerPC User 
Instruction Set Architecture (Book |). For details about the performance of the various 
instructions, see Table 8-1 of this manual. 
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7.1.8.1 MOVE TO/FROM SYSTEM REGISTER INSTRUCTIONS. Move to/from invalid 
special registers in which spr =1 invokes the privilege instruction error interrupt handler if 
the processor is in problem state (user mode). For a list of all implemented special registers, 
refer to Section 6.4.1 Control Registers. 


7.1.8.2 FIXED-POINT ARITHMETIC INSTRUCTIONS. If you try to perform any of the 
following divisions using the divwf[o]f[.] instruction 


Ox80000000 ~= -1 
<anything> + 0 


then, the contents of RT are Ox80000000 and if Rc =1, the contents of the bits in the CR field 
O are LT = 1, GT =0, EQ =O, and SO is set to the correct value. 


In the cmpi, cmp, cmpli, and cmpl instructions, the L bit is applicable for 64-bit 
implementations. For the MPC823, if L = 1 the instruction form is invalid. The core ignores 
this bit and, therefore, the behavior when L = 1 is identical to the valid form instruction with 
L=0. 


7.1.9 The Load/Store Processor 


The load/store processor supports all of the 32-bit implementation fixed-point PowerPC 
load/store instructions in the hardware. 


7.1.9.1 FIXED-POINT LOAD WITH UPDATE AND STORE WITH UPDATE 
INSTRUCTIONS. For load with update and store with update instructions where RA =0, the 
EA is written into RO. For load with update instructions where RA = RT, RA is boundedly 
undefined. 


7.1.9.2 FIXED-POINT LOAD AND STORE MULTIPLE INSTRUCTIONS. For these types 
of instructions, EA must be a multiple of four. If it is not, the system alignment error handler 
is invoked. For a Imw instruction (if RA is in the range of registers to be loaded), the 
instruction completes normally. RA is then loaded from the memory location as follows: 


RA <- MEM(EA+(RA-RT)*4, 4) 


7.1.9.3 FIXED-POINT LOAD STRING INSTRUCTIONS. Load string instructions behave 
the same as load multiple instructions, with respect to invalid format in which RA is in the 
range of registers to be loaded. If RA is in the range, it is updated from memory. 


7.1.9.4 STORAGE SYNCHRONIZATION INSTRUCTIONS. For these type of instructions, 
EA must be a multiple of four. If it is not, the system alignment error handler is invoked. 


7.1.9.5 OPTIONAL INSTRUCTIONS. No optional instructions are supported. 


7.1.9.6 LITTLE-ENDIAN BYTE ORDERING. The load/store unit supports little-endian byte 
ordering as specified in the PowerPC User Instruction Set Architecture (Book I). |n 
little-endian mode, if an attempt is made to execute an individual scalar unaligned transfer, 
as well as a multiple or string instruction, an alignment interrupt is taken. 
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7.2 POWERPC VIRTUAL ENVIRONMENT ARCHITECTURE (BOOK Il) 
7.2.1 Storage Model | 


The MPC823 caches are structured as follows: 


e Physically addressed split 2K instruction cache and 1K data cache 
e Two-way set associative managed with LRU replacement algorithm 
e 16-byte (4 words) line size with one valid bit per line 


7.2.1.1 MEMORY COHERENCE. Hardware memory coherence is not supported in the 
MPC823 hardware, but can be performed in the software or by defining storage as cache 
inhibited. In addition, the MPC823 does not provide any data storage attributes to an 
external system. 


7.2.1.2 ATOMIC UPDATE PRIMITIVES. Both the Iwarx and stwex instructions are 
implemented according to the PowerPC architecture requirements. When the storage 
accessed by the Iwarx and stwex instructions is in the cache-allowed mode, it is assumed 
that the system works with the single master in this storage region. Therefore, if a data 
cache miss occurs, the access on the internal and external buses does not have a 
reservation attribute. 


The MPC823 does not cause the system data storage error handler to be invoked if the 
storage accessed by the Iwarx and stwex instructions is in the writethrough required mode. 
Also, the MPC823 does not provide support for snooping an external bus activity outside the 
chip. The provision is made to cancel the reservation inside the MPC823 by using the CR_B 
and KR_B input pins. Data cache has a snoop logic to monitor the internal bus for 
communication processor module accesses of the address associated with the last lwarx 
instruction. 


7.2.2 The Effect Of Operand Placement on Performance 


The load/store unit hardware supports all of the PowerPC load/store instructions. An optimal 
performance can be obtained for naturally aligned operands. These accesses result in 
optimal performance for a maximum size of four bytes and good performance for double 
precision floating-point operands. Unaligned operands are supported in the hardware and 
are broken into a series of aligned transfers. The effect of operand placement on 
performance is as stated in the PowerPC Virtual Environment Architecture (Book II), except 
for the case of 8-byte operands. Because the MPC823 uses a 32-bit wide data bus, the 
performance is good rather than optimal. Refer to Section 6.6.6 Executing Unaligned 
Instructions for a description of fixed-point unaligned instruction execution and timing and 
to Section 6.6.9 Instruction Timing for a description of string instruction timing. 
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7.2.3 The Storage Control Instructions 


The MPC823 interprets the cache control instructions (icbi, isync, dcbt, dcbi, dcbf, dcbz, 
dcbst, eieio, and dcbtst) as if they pertain only to the MPC823 cache. These instructions 
do not broadcast. Any bus activity caused by these instructions is what happens when an 
operation is performed on the MPC823 cache. 


Instruction Cache Block Invalidate (icbi)—The effective address is translated by the 
memory management unit and the associative block in the instruction cache is 
invalidated if hit. 


Instruction Synchronize (isync)—The isync instruction waits for all previous 
instructions to complete and then discards any prefetched instructions, thus causing 
subsequent instructions to be fetched or refetched from memory and executed. 


Data Cache Block Touch (dcbt)—The block associated with this instruction is checked 
for hit in the cache. If it is a miss, the instruction is treated as a regular miss, except that 
the bus error does not cause an interrupt. If no error occurs, the line is written into the 
cache. 


Data Cache Block Touch for Store (dcbtst)—The block associated with this instruction 
is checked for a hit in the cache. If it is a miss, the instruction is treated as a regular 
miss, except that bus error does not cause an interrupt. If no error occurs, the signal is 
written into the cache. 


Data Cache Block Set to Zero (dcbz)—This instruction is executed according to how it 
is defined in the PowerPC Virtual Environment Architecture Book II. 


Data Cache Block Store (dcbst)—This instruction is executed according to how it is 
defined in the PowerPC Virtual Environment Architecture Book Il. 


Data Cache Block Invalidate (dcbi)—The effective address is translated by the memory 
management unit and the associative block in the data cache is invalidated if hit. 


Data Cache Block Flush (dcbf)—This instruction is executed according to how it is 
defined in the PowerPC Virtual Environment Architecture Book Il. 


Enforce In-Order Execution of I/O (eieio)—When executing an eleio instruction, the 
load/store unit waits until all previous accesses have terminated before issuing cycles 
associated with load/store instructions after the eieio instruction. 


7.2.4 Timebase 


A description of the timebase register can be found in Section 12 System Interface Unit 
and Section 5 Clocks and Power Control. 
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7.3 POWERPC OPERATING ENVIRONMENT ARCHITECTURE (BOOK Ill) 


The MPC823 has an internal memory space that includes memory-mapped control registers 
and memory that is used by various modules on the chip. This memory is part of the main 
memory as seen by the core but cannot be accessed by any external system master. 


7.3.1 The Branch Processor 


7.3.1.1 MACHINE STATE REGISTER. The floating-point exception mode is ignored by the 
MPC823. The IP bit initial state after reset is set as programmed by the reset configuration 
specified in Section 12 System Interface Unit. 


7.3.1.2 PROCESSOR VERSION REGISTER. The value of the PVR register’s version field 
is x’‘0050’. The value of the revision field is x’0000’ and it is incremented each time that the 
software distinguishes between the core revisions. 


7.3.1.3 BRANCH PROCESSORS INSTRUCTIONS. The core implements all the 
instructions defined for the branch processor in the PowerPC User Instruction Set 
Architecture Book | in the hardware. For the details about the performance of various 
instructions, see Table 8-1 of this manual. 


7.3.2 The Fixed-Point Processor 
7.3.2.1 UNSUPPORTED REGISTERS. The following registers are not supported by the 


_MPC823. Refer to Section 7.3.3 Storage Model for more details. 


SDR 1 IBAT2U DBAT1U IBATOL IBATSL DBAT2L 


EAR IBAT2L DBATIL IBAT1U | DBATOU DBAT3U 
IBATOU IBAT3U DBAT2U IBATIL DBATOL DBAT3L 


7.3.2.2 ADDED REGISTERS. For a list of the added special purpose registers, see 
Table 6-9. | = 


7.3.3 Storage Model 


Page sizes are 4K, 16K, 512K, and 8M and an optional sub-page granularity of 1K for 4K 
pages in a maximum real memory size of 4G. Neither ordinary or direct-store segments are 
supported. 


7.3.3.1 ADDRESS TRANSLATION. If address translation is disabled (MSRjp =0 for 
instruction accesses or MSRpp =0 for data accesses), the effective address is treated as the 
real address and is passed directly to the memory subsystem. Otherwise, the effective 
address is translated by using the translation lookaside buffer (TLB) mechanism of the 
memory management unit (MMU). Instructions are not fetched from no-execute or guarded 
storage and data accesses are not executed speculatively to or from the guarded storage. 
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The features of the MMU hardware is as follows: 


e 32-entry fully associative instruction TLB 

¢ 32-entry fully associative data TLB 

e Supports up to 16 virtual address spaces 

e Supports 16 access protection groups 

e Supports fast software tablewalk mechanism 
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7.3.4 Reference and Change Bits 


No reference bit is supported by the MPC823. However, the change bit is supported by 
using the data TLB error interrupt mechanism when writing to an unmodified page. 





7.3.5 Storage Protection 
Two main protection modes are supported by the MPC823: 


e Domain manager mode 
e PowerPC mode 


For more details, refer to Section 11 Memory Management Unit. 


7.3.6 Storage Control Instructions 


7.3.6.1 DATA CACHE BLOCK INVALIDATE (dcbi). This instruction is executed 
according to the definition in PowerPC Operating Environment Architecture (Book III). 


7.3.6.2 TLB INVALIDATE ENTRY (tlbie). This instruction is performed as defined by the 
architecture, except that the 22 most-significant bits of the EA are used for address 
compare. 


7.3.6.3 TLB INVALIDATE ALL (tibia). This instruction is performed as defined by the 
architecture. 


7.3.6.4 TLB SYNCHRONIZE (tlbsync). This instruction is implemented like a regular 
mtspr instruction as it relates to engine synchronization with no further effects. 


7.3./ Interrupts 


7.3.7.1 CLASSES. All interrupts associated with storage are implemented as precise 
interrupts by the core, which means that a Joad/store instruction is not complete until all 
possible error indications are sampled from the load/store bus. This also implies that a store 
or nonspeculative load instruction is not issued to the load/store bus until all previous 
instructions have completed. If a late error occurs, a store cycle (or a nonspeculative load 
cycle) can be issued and aborted. 
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7.3.7.2 PROCESSING. In each interrupt handler, when registers SRRO and SSRi1 are 
saved, MSRp, can be set to 1. 


7.3.7.3 DEFINITIONS. The following table defines the offset value by interrupt type and the 
sections that follow describe each interrupt in detail. 


Table 7-1. Offset of First Instruction by Interrupt Type 
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01F00 Implementation-Dependent Nonmaskable Development Port 


01400 Implementation-Dependent Data TLB Error 
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7.3.7.3.1 System Reset Interrupt. A system reset interrupt occurs when the IRQO pin is 
asserted and the following registers are set. Execution begins at physical address 0x100 if 
the hard reset configuration word IIP bit is 1. Execution begins at physical address 
OxFFFOO100 if the hard reset configuration word IIP bit is 0. | 


SRRO—Save/Restore Register 0 


Set to the effective address of the next instruction the processor executes if no interrupt 
conditions are present. 
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SRR1—Save/Restore Register 1 


Used to save the machine status prior to exceptions and to restore status when an rfi 
instruction is executed. | 





1—4 Set to 0. 

10-15 Setto0O. 

Other Loaded from bits 16-31 of the MSR. In the current implementation, Bit 30 of 
the SRR1 is never cleared, except by loading a zero value from MSRg. 


MSR—Machine State Register 


IP No change. 

ME No change. 

LE Bit is copied from the ILE. 
Other Setto 0. 


7.3.7.3.2 Machine Check Interrupt. A machine check interrupt indication is received from 
the U-bus as a response to the address or data phase. It is usually caused by one of the 
following conditions: 


e The accessed address does not exist 
e A data error is detected 


As defined in PowerPC Operating Environment Architecture (Book III), machine check 
interrupts are enabled when MSRy_e =1. If MSRye = O and a machine check interrupt 
indication is received, the processor enters the checkstop state. The behavior of the core in 
checkstop state is dependent on the working mode as defined in Section 20.4.2.1 Debug 
Mode Enable vs. Debug Mode Disable. When the processor is in debug mode enable, it 
enters the debug mode instead of the checkstop state. When in debug mode disable, 
instruction processing is suspended and cannot be restarted without resetting the core. 


An indication that can generate an automatic reset in this condition is sent to the system 
interface unit. Refer to the Section 12 System Interface Unit for more details. If the 
machine check interrupt is enabled (MSRye =1) it is taken. If SRR1 Bit 30 =1, the interrupt 
is recoverable and the following registers are set. 





SRRO—Save/Restore Register 0 
Set to the effective address of the instruction that caused the interrupt. 
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SRR1—Save/Restore Register 1 


1 Set to 1 for instruction fetch-related errors and 0 for load/store-related errors. 

2-4 Set to 0. 

10-15 Setto0. 3 

Other Loaded from bits 16-31 of the MSR. In the current implementation, Bit 30 of 
the SRR1 is never cleared, except by loading a zero value from MSR. 


MSR—Machine State Register 


IP No change. 

ME Set to 0. 

LE Bit is copied from the ILE. 
Other Setto0. 


When using the load/store bus, the following registers are set: 


DSISR—Data/Storage Interrupt Status Register 


0-14 Set to 0. 

15-16 Setto bits 29-30 of the instruction if X-form instruction and to Ob0O0O if D-form. 
17 Set to Bit 25 of the instruction if X-form instruction and to Bit 5 if D-form. 
18-21 Setto bits 21-24 of the instruction if X-form instruction and to bits 1-4 if D-form. 
22-31 Setto bits 6-15 of the instruction. 


DAR—Data Address Register 
Set to the effective address of the data access that caused the interrupt. 


Execution resumes at offset x’00200’ from the base address indicated by MSRip. 


7.3.7.3.3 Data Storage Interrupt. A data storage interrupt is never generated by the 
hardware. However, the software may branch to this location as a result of either an 
implementation-specific data TLB error or miss interrupt. 


7.3.7.3.4 Instruction Storage Interrupt. An instruction storage interrupt is never 
generated by the hardware, but the software may branch to this location as a result of an 
implementation-specific instruction TLB error interrupt. 


7.3.7.3.5 Alignment Interrupt. An alignment interrupt occurs as a result of one of the 


following conditions: 


e The operand of a floating-point load or store is not word aligned. 
e The operand of a load/store multiple is not word aligned. | 
e The operand of a Iwarx or stwex is not word aligned. 


e The operand of a load/store individual scalar instruction is not naturally aligned 
when MSR, -= 1. 


e An attempt to execute a multiple/string instruction is made when MSR, _ = 1. 
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7.3.7.3.6 Program Interrupt. The MPC823 cannot generate a floating-point exception type 
interrupt. Likewise, an illegal instruction type program interrupt is not generated by the core, 
but an implementation-dependent software emulation interrupt is generated instead. A 
privileged instruction program interrupt is generated for an on-core valid special-purpose 
register (SPR) field or any SPR encoded as an external special register if SPR, =1 and 
MSRpp =1, as well as if you try to execute privileged instruction occurred when MSRopp =1. 
See Table 6-11 for details. 


7.3.7.3.7 Floating-Point Unavailable Interrupt. The MPC823 cannot generate a 
floating-point exception type interrupt. An implementation-dependent software emulation 
interrupt will be taken when you try to execute floating-point instruction, regardless of 
MSRep. 


7.3.7.3.8 Trace Interrupt. A trace interrupt occurs if MSRe- = 1 and any instruction except 
rfi is successfully completed or if MSRg- = 1 and a branch is completed. Notice that the trace 
interrupt does not occur after an instruction that causes an interrupt. The monitor/debugger 
software must change the vectors of other possible interrupt addresses to single-step these 
instructions. If this is unacceptable, other debug features can be used. Refer to 

Section 20 Development Capabilities and Interface for more information. The following 
registers are set on a trace interrupt: 


SRRO—Save/Restore Register 0 
Set to the effective address of the instruction following the executed instruction. 


SRR1—Save/Restore Register 1 
1—4 Set to 0. 
10-15 Setto0. 
Other Loaded from bits 16-31 of the MSR. In the current implementation, Bit 30 of 
the SRR1 is never cleared, except by loading a zero value from MSRp. 


MSR—Machine State Register 
IP No change. 
ME No change. 
LE Bits are copied from the ILE. 
Other Setto0. 


Execution resumes at offset x OODOO’ from the base address indicated by MSR pp. 
7.3.7.3.9 Floating-Point Assist Interrupt. The floating-point assist interrupt is not 


generated by the MPC823. An implementation-dependent software emulation interrupt will 
be taken when you try to execute a floating-point instruction. 
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7.3.7.3.10 Implementation-Dependent Software Emulation Interrupt. An 
implementation-dependent software emulation interrupt occurs as a result of one of the 
following conditions: 


e When executing any unimplemented instruction, including all illegal and 
unimplemented optional and floating-point instructions. 


e When executing a mtspr or mfspr that specifies an on-core unimplemented register, 
regardless of SPR. 


e When executing a mtspr or mfspr that specifies an off-core unimplemented register 
and SPR, =0 or MSRpp =0 (no program interrupt condition). For more information, refer 
to Section 7.3.7.3.6 Program Interrupt. 


In addition, the following registers are set: 


SRRO—Save/Restore Register 0 
Set to the effective address of the instruction that caused the interrupt. 


SRR1—Save/Restore Register 1 
1-4 Set to 0. 
10-15 Setto0O. | 
Other Loaded from bits 16-31 of the MSR. In the current implementation, Bit 30 of 
the SRR1 is never cleared, except by loading a zero value from MSRp). 


MSR—Machine State Register 
IP No change. 
ME No change. 
LE Bits are copied from the ILE. 
Other Set to 0. 


Execution resumes at offset x’01000’ from the base address indicated by MSRpp. 


7.3.7.3.11 Implementation-Specific Instruction TLB Miss Interrupt. This type of 
interrupt occurs if MSRi,_ =1 and you try to fetch an instruction from a page whose effective 
page number cannot be translated by TLB. The following registers are set: 


SRRO-Save/Restore Register 0 
Set to the effective address of the instruction that caused the interrupt. 


SRR1—Save/Restore Register 1 
0-3 Set to 0. 
4 Set to 1. 
10 Set to 1. 
11-15 Setto0O. 
Other Loaded from bits 16-31 of the MSR. In the current implementation, Bit 30 of 
the SRR1 is never cleared, except by loading a zero value from MSRp. 
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MSR—Machine State Register 


IP ~ No change. 
ME No change. 
LE Bits are copied from the ILE. 


Other Setto0. 


Some instruction TLB registers are set to the values described in 
Section 11 Memory Management Unit. Execution resumes at offset x’01100’ from the 
base address indicated by MSRip. 
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7.3.7.3.12 Implementation-Specific Instruction TLB Error Interrupt. This type of 
interrupt occurs as a result of one of the following conditions: 


e The effective address cannot be translated. Either the segment or page valid bit of this 
page is cleared in the translation table. 


e The fetch access violates storage protection. 
e The fetch access is to guarded storage and MSR, =1. 


The following registers are set: 


SRRO—Save/Restore Register 0 
Set to the effective address of the instruction that caused the interrupt. 


SRR1—Save/Restore Register 1 


1 Set to 1 if the translation of an attempted access is not found in the translation 
tables. Otherwise, set to 0. 

2 Set to 0. 

3 Set to 1 if the fetch access was to a guarded storage when MSRijp = 1 Or When 
bit 4 is set. Otherwise, set to 0. 

4 Set to 1 if the storage access is not permitted by the protection mechanism; 


otherwise set to 0. In the first revision when this bit is set, Bits 3 and 10 are 
also set, but in future revisions this bit may be set alone. 

10 Set to 1 when Bit 4 is set. Otherwise, set to 0. 

11-15 Setto0O. 

Other Loaded from bits 16-31 of the MSR. In the current implementation, Bit 30 of 
the SRR1 is never cleared, except by loading a zero value from MSRp,. 


MSR—Machine State Register 


IP No change. 
ME No change. 
LE Bits are copied from the ILE. 


Other Setto 0. 
Some instruction TLB registers are set to a value described in 


Section 11 Memory Management Unit. Execution resumes at offset x’01300’ from the 
base address indicated by MSR pp. 
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7.3.7.3.13 Implementation-Specific Data TLB Miss Interrupt. This type of interrupt - 
occurs when MSRppr =1 and you try to access a page whose effective page number cannot 
be translated by TLB. The following registers are set: 


SRRO—Save/Restore Register 0 
Set to the effective address of the instruction that caused the nfernipt 


SRR1—Save/Restore Register 1 
1-4 Set to 0. 
10-15 Setto0O. _ 
Other Loaded from bits 16-31 of the MSR. In the current implementation, Bit 30 of 
the SRR1 is never cleared, except by loading a zero value from MSRp,. 


~ MSR—Machine State Register 


IP No change. 
ME No change. 
LE Bits are copied from the ILE. 


Other Setto 0. 


Some instruction TLB registers are set to the values described in 
Section 11 Memory Management Unit. Execution resumes at offset x’01200’ from the 
base address indicated by MSR pp. 


7.3.7.3.14 Implementation-Specific Data TLB Error Interrupt. This type of interrupt 
occurs as a result of one of the following conditions: 


¢ No effective address of a load, store, icbi, dcbz, dcbst, dcbf or dcbi instruction can 
be translated (either the segment or page valid bit of this page is cleared in the 
translation table). 


¢ The access violates storage protection. 
_¢ An attempt was made to write to a page with a negated change bit. 


The following registers are set: 


SRRO—Save/Restore Register 0 
Set to the effective address of the instruction that caused the interrupt. 


SRR1i—Save/Restore Register 1 
1-4 Set to 0. 
10-15 Setto0O. 
Other Loaded from bits 16-31 of the MSR. In the current implementation, Bit 30 of 
the SRR1 is never cleared, except by loading a zero value from MSR»). 
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MSR—Machine State Register 


IP No change. 

ME No change. 

LE Bits are copied from the ILE. 
Other Setto0. 


DSISR—Data/Storage Interrupt Status Register 
0 Set to 0. 
1 Set to 1 if the translation of an attempted access is not found in the translation 
tables. Otherwise, set to 0. 
2-3 Set to 0. 
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4 Set to 1 if the storage access is not permitted by the protection mechanism; 
otherwise set to 0. | | 

5 Set to 0. | 

6 Set to 1 for a store operation and to 0 for a load operation. 


7-31 Set to 0. 


DAR—Data Address Register 
Set to the effective address of the data access that caused the interrupt. 


Some instruction TLB registers are set to the values described in 
Section 11 Memory Management Unit. Execution resumes at offset x’01400’ from the 
base address indicated by MSR. 


7.3.7.3.15 Implementation-Specific Debug Register. An implementation-specific debug 
interrupt occurs as a result of one of the following conditions: 


e When there is an internal breakpoint match (for more details, refer to 
Section 20.3 Generating Watchpoints And Breakpoints). - 


e When a peripheral breakpoint request is presented to the interrupt mechanism. 
e When the development port request is presented to the interrupt mechanism. Refer to 


Section 20 Development Capabilities and Interface for details on how to generate 
the development port request. 


The following registers are set: 


SRRO—Save/Restore Register 0 


For l-breakpoints, set to the effective address of the instruction that caused the interrupt. For 
L-breakpoint, set to the effective address of the instruction following the instruction that 
caused the interrupt. For development port maskable request or a peripheral breakpoint, set 
to the effective address of the instruction that the processor would have executed next if no 
Interrupt conditions were present. If the development port request is asserted at reset, the 
value of SRRO is undefined. | 
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PowerPC Architecture Compliance 


SRR1—Save/Restore Register 1 


1—4 Set to 0. 

10-15 Setto0. 

Other Loaded from bits 16-31 of the MSR. In the current implementation, Bit 30 of 
the SRR1 is never cleared, except by loading a zero value from MSR_p. 


If the development port request is asserted at reset, the value of SRR1 is undefined. 


MSR—Machine State Register — 


IP No change. 

ME No change. 

LE Bits are copied from the ILE. 
Other Setto0O. 


For L-bus breakpoint instances, the following registers are set to: 


BAR—Breakpoint Address Register 


Set to the effective address of the data access as computed by the instruction that caused 
the interrupt. 


DSISR—Data/Storage Interrupt Status Register 
Do not change. 


DAR—Data Address Register 
Do not change. 


The execution resumes irom an address equal to the base Indieated by the MSRip and the 
following offset. 


e x’01D00’—For an instruction breakpoint match | 
¢ x'01C00’—For a data breakpoint match 
¢ x’01E00’"-For a development port maskable request ora peripheral breakpoint 
¢ x’01F00’—For a development port nonmaskable request 
7.3.7.4 PARTIALLY EXECUTED INSTRUCTIONS. In general, the architecture allows | 


instructions to be partially executed when an alignment or data storage interrupt occurs. In 
the core, instructions are not executed if an alignment interrupt condition is detected or if a 


_ data storage interrupt is never generated by the hardware. In the MPC823, the instruction 


can be partially executed only in the case of load/store instructions that cause multiple 
access to the memory subsystem—multiple/string and unaligned load/store instructions. 


In this instance, the instruction can be partially completed if one of the accesses (except the 


first one) causes a miss in the data TLB. The implementation-specific data TLB miss 
interrupt is taken in this case. For the update forms, the update register (RA) is not altered. 
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7.3.8 Timer Facilities 


Descriptions of the timebase and decrementer registers can be found in 
Section 12 System Interface Unit and Section 5 Clocks and Power Control. 


7.3.9 Optional Facilities and Instructions 


Any other PowerPC Operating Environment Architecture (Book I/l) optional facilities and 
instructions that are not discussed here are not implemented by the MPC823 hardware. Any 
attempt to execute any of these instructions causes an implementation-dependent software 
emulation interrupt to occur. 
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SECTION 8 
INSTRUCTION EXECUTION TIMING 


This section describes the timing of the instruction cycles in terms of clock cycles, including 
serialization, latency, and blockage. 


8.1 INSTRUCTION TIMING LIST 


The following table lists the instruction execution timing in terms of latency and blockage of 
the appropriate execution unit. A serializing instruction has the effect of blocking all 
execution units. 


Table 8-1. Instruction Execution Timing 


INSTRUCTIONS LATENCY BLOCKAGE EXECUTION SERIALIZING 
UNIT INSTRUCTION 
Branch Instructions: Branch Unit 
b, ba, bl, bla, bc, bca, bel, bcla, belr, 
belrl, bectr, bcctl Not Taken 1 ce 


system Call Naucatial +2 oe | +2 


SC, tfi 
al ae 
Serialize + 3 
ell oe 
Yes 


Not Taken 1 
Except mtspr to LR and CTR and 


Serialize + 1 Serialize + 1 
External to the Core Registers 


Move to LR, CTR Branch Unit 
mtspr 


z 
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— 
©. 
re 
>< 
fr 
z 
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oO 
=| 
cc 
= 
n 
= 










8] 


















CR Logical: 
crand, crxor, cror, crnand, crnor, 
crandc, creqv, crorc, merf 











Fixed-Point Trap Instructions: 
twi, tw 








Move to Special Registers: 
mtspr, mtcrf, mtmsr, merxr 






“ 
es 






Move to External to the Core Serialize + a Serialize + 1 LDST 
Special Registers: 
mtspr, mttb, mttbu 

Load Latency i LDST 
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Move from External to the Core 
Special Registers: 
mfspr, mftb, mftbu 







Move from Special Registers 
Located Internal to the Core: 
mfspr! 
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Table 8-1. Instruction Execution Timing (Continued) 


INSTRUCTIONS LATENCY BLOCKAGE EXECUTION SERIALIZING 
INSTRUCTION 
Move from Others: Serialize + 1 Serialize + 1 
mfcr, mfmsr 


Fixed-Point Arithmetic: ALU at BFU 
addi, add[o][.], addis, subf[o][.], addic, 

subfic, addic., addc[o][.], adde[o][.], 

subfc[o][.], subfe[o][.], addmef[o][.], 

addze[o][.], subfme[o][.], subfze[o][.], 

neg[oll.] 

Fixed-Point Arithmetic Min 2 Min 2 IMUL / IDIV 
(Divide Instructions): Max 114 Max 11° 

divw[o][.], divwu[o][.] 

Fixed-Point Arithmetic IMUL / IDIV 
(Multiply Instructions): 

mul, mullw[o]f.], mulhw([.], mulhwuf[.] 

Fixed Point Compare: ALU / BFU 
cmpi, cmp, cmpli, cmp! 

Fixed-Point Logical: nies ALU / BFU 
andi., andis., ori, oris, xori, xoris, 
and[.], or[.], xor[.], nand[.], nor[.], 


eqv[.], andc[.], orc[.], extsb[.], 
extsh[.], cntlzw[.] 
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Fixed-Point Rotate and Shift: 
rlwinm[.], rlwnm{.], rlwimil.], slw[.], 
srw{[.], srawil.], sraw[.] 








Fixed-Point Load Instructions: 
Ibz, Ibzu, lbzx, Ibzux, Ihz, Ihzu, Ihzx, 

Ihzux, Ilha, Ihau, Ihax, Ihaux, lwz, lwzu, 
Iwzx, lwzux, lhbrx, Iwbrx. 









Fixed-Point Store Instructions: 
stb, stbu, stbx, stbux, sth, sthu, sthx, 
sthux, stw, stwu, stwbrx, stwx, stwux, 
sthbrx 
























Serialize + 1 
+ Number of 


Fixed-Point Load and Store Serialize + 1 


Multiple Instructions: + Number of 
Imw, smw Registers Registers 


Synchronize: Serialize + 1 Serialize + 1 LDST 

sync 

Storage Synchronization Instructions: Serialize + 2 Serialize + 2 LDST 

lwarx, stwex. 

Move Condition Register from XER: LDST Yes (Before) 
mcerxr 


Move to / from Special Purpose Serialize + 1 Serialize + 1 LDST Yes (Before) 
Register (Debug, DAR, DSISR): 
Serialize + 1 Serialize + 1 LDST 
+ Number + Number 
of Words of Words 
Accessed Accessed 


mtspr, mfspr 
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String Instructions: 
Iswi, Iswx, stswi, stswx 
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Table 8-1. Instruction Execution Timing (Continued) 
EXECUTION | SERIALIZING 


INSTRUCTIONS LATENCY BLOCKAGE 
UNIT INSTRUCTION 
isync 


Order Storage Access: 1 1 LDST Next Load or Store 
eieio is Synchronized 
Relative to All Prior 
Load or Store 


Cache Control: 1 1 LDST, No 
icbi Il-Cache 


NOTES: Refer to Table 6-11 for details. 
Refer to Section 6.4.1 Control Registers. 
See Table 6-10 for details. 
















See Ie 


NoOverflow = 3 + aan 


4 
DivisionLatency = 
Overflow => 2 


—s 
© 
= 
| 
oO 
Lu 
>< 
Lu 
= 
© 
- 
(>) 
a) 
co 
= 
<2) 
= 


Where: 


© 





Overflow = (*)o(ae 
“(0 = 


DivisionBlockage = DivisionLatency 


6. Blocking the multiply instruction is dependent on the subsequent instruction. For any subsequent 
multiply instruction, the blockage is 1 clock and for any subsequent divide it is 2 clocks. 


7. Assuming nonspeculative aligned access, on-chip memory, and available bus. For details, refer to 
Section 6.6.5 Issuing Nonspeculative Load Instructions, Section 6.6.6 Executing Unaligned 
Instructions, and Section 6.6.9 Instruction Timing. 


8. Although a store (as well as mtspr for special registers external to the core) issued to the load/store 
unit buffer frees the core pipeline, the next load or store will not actually be performed on the bus until 
the bus is free. 
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Instruction Execution Timing 


8.2 INSTRUCTION EXECUTION TIMING EXAMPLES 


All examples assume an instruction cache hit. 


8.2.1 Data Cache Load 


Iwz 112,64 (SP) 
sub r3,1r12,3 
addic r4,r14,1 
mulli +5,7r3,3 
addi 1r4,3(xr0) 


| 
rere june sven Xo 


I 
I 

DECODE LWZ ADDIC 
t 


3 wz) (ebbeké 
WRITEBACK ! 
i 
I 





L ADDRESS DRIVE 
I 

Pe cael ae a ee 
I 

LOADWRITEBACK 





Figure 8-1. Example of a Data Cache Load 


This is an example from a data cache with zero wait states. The sub instruction is dependent 
on the value loaded by the load to r12. This causes a bubble to occur in the instruction 
stream as shown in the execute line. Refer to Section 8.2.2.2 Private Writeback Bus Load 
for instances in which no such dependency exists. 


8-4 MPC823 USER’S MANUAL MOTOROLA 


Instruction Execution Timing 


8.2.2 Writeback 
8.2.2.1 WRITEBACK ARBITRATION 
mulli r12,r4,3 


sub +3,1r15,3 
addic r4,r12,1 


GCLK1 | | | | | | | | | | | | | | | 
FETCH MULL SUB ADDIC 


— an 7 —— — 


I 
i 
i 
DECODE ; 
I 


READ + EXECUTE 












WRITEBACK 


Figure 8-2. Example of a Writeback Arbitration 


Sd] 
The addic instruction is dependent on the mulli result. Since the single-cycle instruction 
sub has priority on the writeback bus over the mulli and the mulli writeback is delayed one 
clock and causes a bubble in the execute stream. 


mulli +12,1r4,3 
sub +3,1r15,3 
addic r4,1r3,1 


GCLK1 | | | | | | | | | | | | | | | 


FETCH MULL ADDIC 


eae eS cue | annanssenacensenananenanasnanenastanmensasesconsssnnccansasssonns AAnanannneanssspQnnnnnnanahessheas*sannnessseageannsnnnsnssssnisacassinsshnnanesnananAnAinriaanannnARtiAadnnnnaRAntnanneheannnanAnnhAdRinARAAARARAheadQiMInAnnaASeanenannnnnnasenensannnnnnasseshenannnsnmnsas Qaasnnanassanansane 


! | 
1 4 
] 


READ +EXECUTE | MULLI FADpIc) 


(eae ae 


Figure 8-3. Another Example of a Writeback Arbitration 


DECODE 
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Instruction Execution Timing 


In this example, the addic instruction is dependent on the sub rather than on the mulli. 
Although the writeback of the mulli is delayed two clocks, there is no bubble in the execution 
stream. 


8.2.2.2 PRIVATE WRITEBACK BUS LOAD 


Iwz 112,64 (SP) 
sub 1+5,r5,3 
cror 4,14,1 

and) xr3,r4.r5 
xor e457 3005 

or £65712 373 





DECODE 


I 
dss t sd ibs canal aad 5 sibtnatnada nasi si Scbadiccicetaine 
READ +EXECUTE (sub) 
WRITEBACK ) 

4 

| 

I 








L ADDRESS DRIVE LWZ 
i LW. 

ie oemtetenn: Cs sisattheicariaencesicergnsetedianenskasieinesteaieel tenis , 

CACHE ADDRESS 

LOAD WRITEBACK 

E ADDRESS ! LWZ 

E DATA 

setae hie Bs a eee de sche eee Pe ha al iC a aN a a a i an cee a sa 


Figure 8-4. Example of a Private Writeback Bus Load 


The load and the xor writeback in the same clock since they use the writeback bus in two 
different ticks. 
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8.2.3 Fastest External Load (Data Cache Miss) 


Iwz 112,64 (SP) 
sub 1r3,r12,3 
addic r4,r14,1 











] 
: | 
= 5 
freee ae ate I tec 
READ + EXECUTE LWZ ‘ BUBBLE) «BUBBLE» «BUBBLE «+ BUBBLE) ( SUB >< 
= —_— — Sf - ee ee eee ef ow = = af > 
WRITEBACK , 5 
mapereceevevesetesccncaveevveseusscccenseeurevensen seseevouereseereseveansececoueveeee ses j saveernereuvesessseuserreoreverssstensvenreevweesssesencereusuusrseesedseveseerrersesdseenaaaveversyseseeesieweuresyereseeeeetevee reveGsEsesenUETeeey GesesseUnEneTEVGegsereHEESUSEIT TORE OOEREGEUEONUESCOTSPIEEEEEEFEGSICOELYREOEUTES OFOSUEREUUSUTEOTEEOEDEUITETETStSEEESOITOCETESSSGEENSSEEEEETY TC GCCTEUTELEUEOLTTOLECCS OG ETESRENCTEOUSOEET STUDS EOEEE OE > 
L ADDRESS DRIVE ; LWZ = 
, = 
LDATA ! Z 
ae a 
CACHE ADDRESS 00] 
ee av eT Ce SE COENEN | 
1 
LOAD WRITEBACK 
oop e eee eat eee ee ae ee ene cnc. Ee 
E ADDRESS LWZ 


Figure 8-5. Example of an External Load 


The sub instruction is dependent on the value read by the load. It causes three bubbles in 
the instruction execution stream. The external clock is shifted 90° relative to the internal 
clock. 
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8.2.4 A Full History Buffer 


Iwz2 112,64 (SP) 
sub +5,r5,3 
addic r4,r14,1 
and +3,r4.r5 
xor r4,r3,4r5 
ori 4+7,xr8,1 


GCLK1 ~ 


FETCH 


(iz) (He) (oe) (mo) eR 





DECODE 


! 
I 
I 
I 


L ADDRESS DRIVE 





CACHE ADDRESS | 


LOAD WRITEBACK 





E ADDRESS LWZ 


E DATA LWZ 


Figure 8-6. Example of a Full History Buffer 


This example.demonstrates the condition of a full history buffer..In this case, the history 


buffer is full from executing the sub, add, and and instructions. It takes one more bubble 
from the load writeback to allow further issue. This is the time for the history buffer to retire 
sub, add, and and. 
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8.2.5 Branch Folding 


Iwz 112,64 (SP) 
sub r3,r12,3 
addic r4,r14,1 

bl func 


func: 
mulli +5,1r3,3 
addi +4,3(r0) 











z 
Oe ee ee in oe . 
FETCH SUB ADDIC BUBBLE MULLI ADD! a 
tee mee ee a OQ. 

{ ’ 

1 a 
iscussdli saitiehesratitislanatoacomiters altdbensthaseuttetoctindicncd i essccssssstsncabisessegucosthacesseingCStcatsi SS susibcads nantes cs cacesos cto sati Sitcoms cane panos Sodas nabslanaca estoy ivan ees Buda eS csbcieseta cyst dscDsuehiS Sai cs anSblatSus Cantos : re 
DECODE LWZ SUB ADDIC MULLI ae 
Da A A a aR RS SS Ag ASN ER cagA a ge > C5 

r 7 r a [ao > 
READ + EXECUTE ! LWZ (BUBBLE) — « BUBBLE} ADDIC MULLI bs 
TS Ate e eae ee ee 22 
WRITEBACK ADD . 

J , 
LADDRESSDRIVE =| 60] | 
es Ee Oe ee Ae On Tea atl 

l 
L DATA ! 

LOAD WRITEBACK ) 
eect I aha Seat hat Meech en hae oes Pessina eee ct atc chad aca aahetedatechaeeae ec cael asec aapctcaaced acto cesta atest laren nae egress is aoc aca ce ales a att Aust teael a aunstes aaa Maas 

l 
BRANCH DECODE 
BRANCH EXECUTE BL 
eu i: nee 


Figure 8-7. Example of Branch Folding 


The Iwz instruction accesses the internal storage with one wait state. The instruction 
prefetch queue and parallel operation of the branch unit allows the two bubbles caused by 
the bl issue and execution to overlap the two bubbles caused by the load. The issue of the 
branch itself is referred to as a bubble since no actual work is done by a branch. 
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8.2.6 Branch Prediction 


while: 
mulli +3,r12,r4 
addi 14,3(r0) 


Iwz 112,64 (r2) 
cmpi 0,4r12,3 
addic r6,r5,1 

bit cr0,while 














O Pease. ee see ta eee 
23 Se 
52 
= DECODE LWZ | CMPI 
| ao = nc eee , GE — 7 “Sis —_I wean i ——! 
met a el i a ae 
zi LADDRESSDRIVE LWZ 
ihe, snes. en ae 
LOAD WRITEBACK ! LWz 
BRANCHDECODE BLT 
ree ee eam. eee er eee 
BRANCH FINAL BLT 
DECISION 


Figure 8-8. Example of Branch Prediction 


In this example, the bit instruction is dependent on the cmpi instruction. Nevertheless, the 
branch unit predicts the correct path and allows an overlap of its bubbles with those of Iwz. 
When the cmpi writes back, the branch unit reevaluates the decision and if correct 
prediction occurs no more action is taken and execution continues fluently. The fetched 
instructions on the predicted path are not allowed to execute before the condition is finally 
resolved. Instead, they are stacked in the instruction prefetch queue. 
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SECTION 9 
INSTRUCTION CACHE 


The MPC823 instruction cache is a 2K two-way, set associative storage area. It is organized 
into 64 sets, two lines per set and four words per line. Cache lines are aligned on 4-word 
boundaries in memory and can be used as an SRAM that allows the application to lock 
critical code segments that need fast and deterministic execution time. The cache access 
cycle begins with an instruction request from the instruction unit in the core. If a cache hit 
occurs, the instruction is delivered to the instruction unit and if a cache miss occurs, the 
cache initiates a burst read cycle on the internal bus with the address of the requested 
instruction. The first word received from the bus is considered the requested instruction. The 
cache forwards this instruction to the instruction unit of the core as soon as it is received 
from the internal bus. A cache line is then selected to receive the data that will be coming 
from the bus. A least recently used (LRU) replacement algorithm is used to select a line 
when no empty lines are available. 


Each cache line can be used as an SRAM, thus allowing the application to lock critical code 
segments that need fast and deterministic execution time. Instruction cache coherency ina 
multiprocessor environment is maintained by the softwa‘e and supported by a fast hardware 
invalidation capability. Figure 9-1 illustrates a block diagram view of the cache organization 
and Figure 9-2 illustrates a view of the cache’s data path. 


9.1 FEATURES 


The following is a list of the instruction cache’s main features: 


° 2K Two-Way, Set-Associative at Four Words Per Line 
e Implements the LRU Replacement Policy 

e Parked On the Internal Bus 

e Lockable Cache Lines 

e “Critical word first’, Burst Access 


e Contains Stream Hit, Which Allows Fetching from the Burst Buffer and of the Word 
Currently on the Internal Bus 


e Operates in Parallel with the Core to Maximize Performance 
e Cache Control 


11 Supports PowerPC™ invalidate instruction 
[1 Supports load and lock (cache line granularity) 
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Instruction Cache 


9-2 


Supports Cache Inhibit 


Ly As acache mode of operation (cache disable) 
L} On memory regions (Supported by the MMU) 


Efficiently Uses the Pipeline of the Internal Bus by Initiating a New Burst Cycle (If a Miss 
is Detected) While Bringing the Tail of the Previously Missed Line to the Cache. | 


Performance Enhanced for Cache-Inhibited Regions by Fetching a Full Line to the 
Internal Burst Buffer. Instructions Stored in the Burst Buffer and Those Originated in a 
Cache-Inhibited Region Are Only Used Once Before Being Refetched. 


Instruction Unit Request Has Priority Over a Burst Buffer Write to an Array (Burst Buffer 
Holds Last Missed Data), thus Increasing the Overall Core Performance 


Miss Latency is Reduced by Sending Addresses to the Cache and Internal Bus 


Simultaneously and Aborting When a Hit Before a Cycle Goes External — 


Minimum Operational Power Consumption 


Tags and Data er Can be Accessed by the Core for Debugging and Testing 
Purposes | 


Special Support is Available When the MPC823 Processor is in n Debug Mode. Refer to 
Section 9.9 Debug Support for More Information. | 
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Instruction Cache 


27 28 «629 
INSTRUCTION POINTER 


22 


WORD SELECT 


WAYO WAY1 
sero [TACO] | [Wo[Wi[w2 [wa]. [7] - 


aa 
tact —_{_[_[wo [wr [we [Wa 


seri [TAGT__| | [Wo ]WH [we [Wa | 


J rr 


VALID BIT 
LOCK BIT 


VALID BIT 
LOCK BIT 
<>muUDUPYr c 


seve2 [TAGE | [wo [we fwe we} | |-- -rKee— 
sree [Tas —[-Y]we wipe [wa}- |] [Tasso [wo [we we 
90 22 
MMU 4 
y__| 128 





HITO : : : 
‘Oo : 
— BIDIRECTIONAL MUX 2-> 1 2 
7 3 
, ¥ 2 
— 
jam 
-~ 
g 
128 = 
HIT ‘ © ; 
TO LINE BUFFER/ aan 
FROM BURST BUFFER 





Figure 9-1. Instruction Cache Organization Block Diagram 
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Instruction Cache 


ADDRESS [22:27] 


2K 
CACHE 
ARRAY 


SET 
DECODER 


ADDRESS [28:29] 





32 


INSTRUCTION 
TO CORE 
INTERNAL BUS DATA 


Figure 9-2. Cache Data Path Block Diagram 


9.2 PROGRAMMING THE INSTRUCTION CACHE 


Three special-purpose registers can be used to control the instruction cache with the mfspr 
and mtspr instructions: 


e Instruction cache control and status register (IC_CSR) 
¢ Instruction cache address register (IC_LADR) 
e Instruction cache data port register (read-only) (IC_DAT) 


These registers are privileged and any attempt to access them while the core is in the 
problem state (MSRpp =1) results in a program interrupt. 
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Instruction Cache 


9.2.1 Instruction Cache Control and Status Register 


The instruction cache control and status register (IC_CSR) is used to configure and access 
the status of the instruction cache. 


IC_CSR 





RESERVED 


NOTE: — = Undefined. 






lEN—Instruction Cache Enable Status 


This bit is read-only. Any attempt to write it is ignored. Enable or disable the instruction 
cache by writing to the CMD field. 


0 = Instruction cache is disabled. 
1 = Instruction cache is enabled. 


Bits 1-3—Reserved 
These bits are reserved and should be set to 0. 


uw 
on 
oO 
< 
oO 
Zz 
Oo 
a 
oO 
a) 
oc 
— 
7) 
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CMD—Command 


The following commands can be written to the CMD field to control and configure the 
instruction cache. The machine must be in privilege mode (MSRpa=1). 


Oo 


000 = Reserved. 

001 = CACHE ENABLE. 
010 = CACHE DISABLE. 
011 = LOAD & LOCK. 
100 = UNLOCK LINE. 
101 = UNLOCK ALL. 
110 = INVALIDATE ALL. 
111 = Reserved. 





Bits 7-9—Reserved 
These bits are reserved and should be set to 0. 
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Instruction Cache 





CCER1—Instruction Cache Error Type 1 
This field is sticky and set by the hardware. It is read-only and cleared when read. 


No Error. 
Error. 


CCER2—Instruction Cache Error Type 2 
This field is sticky and set by the hardware. It is read-only and cleared when read. 


No Error. 
Error. 


CCER3—Instruction Cache Error Type 3 
This field is sticky and set by the hardware. It is read-only and cleared when read. 


No Error. 
Error. 


Bits 13-31—Reserved | 
These bits are reserved and should be set to 0. 


9.2.2 Instruction Cache Address Register 


The instruction cache register (IC_ADR) contains addresses to be used in the command 
programmed in the IC_CSR. 





NOTE: — = Undefined. 


DR—Address 


his field represents the address to be used in the command programmed in the IC_CSR. 
The format may vary depending on the selected cache operation. 


9-6 MPC8&23 USER’S MANUAL MOTOROLA 


Instruction Cache 


9.2.3 Instruction Cache Data Port Register 


The instruction cache data port register (IC_DAT) contains data that is received from the 
instruction cache. 


IC_DAT 





NOTE: — = Undefined. 


DAT—Data 


This field represents the data received when reading information from the instruction cache. 
The format may vary depending on the selected cache 


9.3 INSTRUCTION CACHE OPERATION 


On an instruction fetch, bits 21-27 of the instruction’s address point into the cache to. retrieve 
the tags and data of one set. The tags from both ways are then compared against bits 0-20 
of the instruction’s address. If a match is found and the matched entry is valid, then it is a 
cache hit. If neither tags match or the matched tag is not valid, it is a cache miss. The 
instruction cache includes one burst buffer that holds the last line received from the bus and 
one line buffer that holds the last line retrieved from the cache array. If the requested data © 
is found in one of these buffers, it can also be considered a cache hit. Refer to Figure 9-2 
for more information. To minimize power consumption, the instruction cache attempts to 
make use of data stored in one of its internal buffers. Using a special indication from the 
core, it is possible to make sure that the requested data is in one of the buffers early enough 
that the cache array is not activated. | | 
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9.3.1 Instruction Cache Hit 


When a cache hit occurs, bits 28-29 of the instruction address are used to select one word ! 
from the cache line whose tag matches the instruction pointer. The instruction Is then 
immediately transferred to the instruction unit of the core. 
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Instruction Cache 


9.3.2 Instruction Cache Miss 


When an instruction cache miss occurs, the address of the missed instruction is driven on 

the internal bus with a 4-word burst transfer read request. A cache line is then selected to 

receive the data that will be coming from the bus. The selection algorithm gives first priority 
to invalid lines. If neither of the two lines in the selected set are invalid, then the least recently 
used line is selected for replacement. Locked lines are never replaced. The transfer begins 
with the word requested by the instruction unit, followed by the remaining words of the line, 
then by the word at the beginning of the lines. 


When the missed instruction is received from the bus, it is immediately delivered to the 
instruction unit and also written to the burst buffer. As subsequent instructions are received 
from the bus, they are written into the burst buffer and delivered to the instruction unit either 
directly from the bus or from the burst buffer. When the line resides in the burst buffer, it is 
written to the cache array as long as it is not busy with an instruction unit request. If a bus 
error is encountered on the access to the requested instruction, then a machine check 
interrupt is taken. If a bus error occurs on any access to other words in the line, then the 
burst buffer is marked invalid and the line is not written to the array. However, if no bus error 
is encountered, the burst buffer is marked valid and eventually written to the array. 


If you receive a cache-inhibit signal, the line is only written to the burst buffer and not to the 
cache. Instructions that are stored in the burst buffer and originate in a cache-inhibited 
memory region are only used once before they are refetched. Refer to 

Section 9.4.6 Instruction Cache Read for more information. 


9.3.3 Instruction Fetch On A Predicted Path 


The core allows branch prediction so branches can issue as early as possible. This 
mechanism allows instruction prefetch to continue while an unresolved branch is being 
computed and the condition is being evaluated. Instructions fetched after unresolved 
branches are considered fetched on a predicted path. These instructions may be discarded 
later if it turns out that the machine has followed the wrong path. To minimize power 
consumption, the MPC823 instruction cache does not initiate a miss sequence in most 
cases when the instruction is inside a predicted path. The MPC823 instruction cache 
evaluates fetch requests to see if they are inside a predicted path and if a hit is detected, the 
requested data is delivered to the core. However, if a cache miss is detected, the miss 
sequence is usually not initiated until the core finishes branch evaluation. 


9.4 INSTRUCTION CACHE COMMANDS 


The MPC823 instruction cache supports the PowerPC invalidate instruction with some 
additional commands that help control the cache and debug the information stored in it. The 
additional commands are implemented using the three special-purpose control registers 
mentioned previously in Section 9.2 Programming the Instruction Cache. Most of the 
commands are executed immediately after the control register is written and unable to 
generate any errors. Therefore, when executing these commands there is no need to check 
the error status in the IC_CSR. | | 
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Some commands may take some time to generate errors. In the current implementation, 
LOAD & LOCK is the only command to which this applies. Therefore, when executing these 
commands, you must insert an isync instruction immediately after the instruction cache 
command and check the error status in the IC_CSR after the isynce. The error type bits in 
the IC_CSR are sticky, thus allowing you to perform a series of instruction cache commands 
before checking the termination status. These bits are set by the hardware and cleared by 
the software. 


Only commands that are not immediately executed need to be followed by an isync 
instruction for the hardware to perform them correctly. However, all commands need to be 
followed by an isync to make sure all instruction fetches that are after the instruction cache 
commands in the program stream are affected by the instruction cache command. When the 
instruction cache is executing a command it is busy, so it stops any treatment of core 
requests. This eventually results in a machine stall. 


9.4.1 Invalidating the Instruction Cache 


The MPC823 implements the PowerPC instruction cache block invalidate (icbi) as it only 
pertains to the MPC823 instruction cache. This instruction does not broadcast on the 
external bus and the MPC823 does not snoop this instruction if it is broadcasted by other 
masters. This command is not privileged and has no associated error cases. The instruction 
cache performs this instruction in one clock cycle. To accurately calculate the latency of this 
instruction, bus latency should be taken into consideration. 


The invalidate all instruction cache operation is privileged and any attempt to perform it 
when the core is in the problem state (MSRp,p =1) results in a program interrupt. When it is 
invoked and MSRpp = O, all valid lines in the cache, except the lines that are locked, are 
made invalid. As a result of this command, the lines’ LRU points to an unlocked Way or to 
Way 0 if both lines are unlocked. This last feature is useful when initializing the instruction 
cache out of reset. For more information, refer to Section 9.8 Reset Sequence. To 
invalidate the whole cache, set the INVALIDATE ALL command in the IC_CSR. This 
command has no associated error cases. The instruction cache performs this instruction in 
one clock cycle. To accurately calculate the latency of this instruction, bus latency should be 
taken into consideration. 
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Instruction Cache 


9.4.2 Loading and Locking the Instruction Cache 


The LOAD & LOCK command is used to lock critical code segments in the instruction 
cache. This operation is privileged and any attempt to perform it when the core is in the 
problem state (MSRpp= 1) results in a program interrupt. LOAD & LOCK is performed on a 
cache line granularity and after a line is locked, it operates as a regular instruction SRAM. It 
is not replaced during misses and it is not affected by invalidation commands. The hardware 
operation trusts the software to follow the exact steps mentioned in Section 9.7 Updating 
Code And Memory Region Attributes. To load and lock a line, follow these steps: 


Read the error type bits in the IC_CSR to clear them. 
Write the address of the line to be locked to the IC_ADR. 
Set the LOAD & LOCK command in the IC_CSR. 


Execute the isync instruction. 
Return to Step 2 to load and lock more lines. 


oF Ol ee SS IS 


Read the error type bits in the IC_CSR to determine if the operation completed 
properly. | 


After the LOAD & LOCK command is written to the IC_CSR, the cache checks to see if the 
line containing the byte addressed by the IC_ADR is in the cache. If it is a hit, the line is 
locked and the command terminates with no exception. If it is not, a regular miss sequence 
is initiated. After the whole line is placed in the cache, the line is locked. You must check the 
error type bits in the IC_CSR to determine if the LOAD & LOCK operation completed 
properly. The LOAD & LOCK command can generate two errors: 


¢ Type 1—A bus error occurs in one of the cycles that fetched the line. 


e Type 2—There is no place to lock. It is your responsibility to make sure that there is at 
least one unlocked way in the appropriate set. 


9.4.3 Unlocking A Line 


The UNLOCK LINE command is used to unlock previously locked cache lines. This 
operation is privileged and any attempt to perform it when the core is in the problem state 
(MSRopp = 1) results in a program interrupt. UNLOCK LINE is performed on a cache line 
granularity. If the line is found in the cache it is considered a hit, thus it is unlocked and 
operates as a regular valid cache line. If the line is not found in the cache it is considered a 
miss, there is no operation and the command terminates without an exception. To unlock a 
line, follow these steps: 


1. Write the address of the line to be unlocked into the IC_ADR. 
2. Set the UNLOCK LINE command in the IC_CSR. 
This command has no error cases that you need to check. The instruction cache performs 


this instruction in one clock cycle. To accurately calculate the latency of this instruction, bus 
latency should be taken into consideration. 
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9.4.4 Unlocking the Entire Instruction Cache 


The UNLOCK ALL command is used to unlock the entire instruction cache. This operation 
is privileged and any attempt to perform it when the core is in the problem state (MSRprp =1) 
results in a program interrupt. It is performed on all cache lines. If a line is locked, it is 
unlocked and operates as a regular valid cache line. If a line is not locked or if it is invalid, 
no operation occurs. To unlock the whole cache, set the UNLOCK ALL command in the 
IC_CSR. This command has no associated error cases. The instruction cache performs this 
instruction in one clock cycle. To accurately calculate the latency of this instruction, bus 
latency should be taken into consideration. 


9.4.5 Inhibiting the Instruction Cache 


In the MPC823, there are two ways to inhibit the cache—using the MMU cache-inhibit 
attribute or the cache disable mode. To disable the instruction cache, set the CACHE 
DISABLE command in the IC_CSR. This operation is privileged and any attempt to perform 
it when the core is in the problem state (MSRpp =1) results in a program interrupt. This 
command has no error cases that you need to check. 


To enable the instruction cache, set the CACHE ENABLE command in the IC_CSR. This 
operation is privileged and any attempt to perform it when the core is in the problem state 
(MSRpp =1) results in a program interrupt. This command has no error cases that you need 
to check. When fetching from cache-inhibited regions the full line is brought to the internal 
burst buffer. Instructions that originate in a cache-inhibited region and are stored in the burst 
buffer can be sent to the MPC823 core no more than once before being refetched. In the 
memory management unit, a memory region can be programmed as cache-inhibited. When 
changing a memory region to be cache inhibited, you must unlock all previously locked lines 
containing code that originated in this memory region, invalidate all lines containing code 
that originated in this memory region, and execute an isync instruction. 


Note: Failure to follow these steps causes code from cache-inhibited regions to be left 
inside the cache and any reference to these regions will result in a cache hit. If 
a reference to a cache-inhibited region results in a cache hit, the data is sent to 
the core from the cache and not from memory. 


When the MPC823 asserts the FRZ signal, it indicates that the MPC823 is under debug and 
all fetches from the cache are treated as if they were from the cache-inhibited memory 
region. For more information on cache debug support, refer to Section 9.9 Debug Support. 
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9.4.6 Instruction Cache Read 


The MPC823 allows you to read all data stored in the instruction cache, including the content 
of the tags array. However, this operation is privileged and any attempt to perform it when 
the core is in the problem state (MUSRpp =1) results in a program interrupt. To read the data 
stored in the instruction cache, follow these steps: 


. Write the address of the data to be read to the IC_ADR. It is also possible to read this 
register for debugging purposes. 


2. Read the IC_DAT register. 


So that it can access all parts of the instruction cache, the IC_ADR is divided into the fields 
shown in the following table. 


IC_ADR (CACHE READ COMMAND FORMAT) 


soos ike * aia’ 


Bits O—17—Reserved 
These bits are reserved and should be set to 0. 


D—Tag or Data Select 


Select tag RAM. 
Select data RAM. 


WAY—Way Select 


Select way 0 of cache array. , 
Select way 1 of cache array. 


—_, 
I] 


Bits 20—21—Reserved 
These bits are reserved and should be set to 0. 


9-12 MPC823 USER’S MANUAL MOTOROLA 


Instruction Cache 


SET—Set Select 
This field is used to select the set index of the cache array. 


WORD—Word Select 
This field is used to select a word within a set and way. 


Bits 30-31—Reserved 
These bits are reserved and should be set to 0. 


When read from the data array, the 32 bits of the word selected by the IC_ADR is placed in 
the targeted general-purpose register. When read from the tag array, the 22 bits of the tag 
and related information that is selected by the IC_ADR are all placed in the targeted 
general-purpose register. The following table provides the bit layout of the instruction cache 
data register when reading a tag. 


IC_DAT (TAG READ FORMAT) 
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TAG—Tag Select 
This field contains the upper 22 bits of the address. 


V—Valid Entry 





0 
1 


Entry is not valid. | 
Entry is valid. 


L—Lock Entry 


O= Entry is unlocked. 
1 = Entry is locked. 


LRU—Least-Recently Used 
This bit indicates that the entry is aged or least recently used. 
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Instruction Cache 


Bits 25—31—Reserved 
These bits are reserved and should be set to 0. 


9.4.7 Instruction Cache Write 


Instruction cache write is only enabled when the MPC823 is in test mode. 


9.5 RESTRICTIONS 


Zero wait state devices that are placed on the internal bus are considered to be in the 
cache-inhibited memory region and the hardware correct operation trusts the software to 
follow the exact steps mentioned in Section 9.7 Updating Code And Memory Region 
Attributes. It is not recommended that you perform LOAD & LOCK from zero wait state 
devices that are placed on the internal bus, especially since it is not guaranteed that the data 
will be fetched from the instruction cache. In most cases, it is fetched from the device, but 
found in the instruction cache. 


9.6 INSTRUCTION CACHE COHERENCY 


Cache coherency in a multiprocessor environment is maintained by the software and 
supported by the invalidation mechanism as described above. All instruction storage is 
considered to be coherent, not required, mode. 


9.7 UPDATING CODE AND MEMORY REGION ATTRIBUTES 


To update the code or change the programming of the memory regions in the chip-select 
logic, follow these steps: 

. Update the code and change the memory region programming in the chip-select logic. 
. Execute the sync instruction to ensure that the update/change operation has finished. 
. Unlock all locked lines that contain code that was updated. 

. Invalidate all lines that contain code that was updated. 

. Execute the isync instruction. 


9.8 RESET SEQUENCE 


To simplify the debug task of the system, the instruction cache is only disabled during 
hardware reset (IC_CSR,_y = 0). This feature enables you to investigate the exact state of 
the instruction cache prior to the event that asserts the reset. To ensure proper operation of 
the instruction cache after reset, the UNLOCK ALL, INVALIDATE ALL, and 
INSTRUCTION CACHE ENABLE commands must be executed. 


oOo ar wn — 
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9.9 DEBUG SUPPORT 


The MPC823 can be debugged either in debug mode or by a software monitor debugger. In 
both cases, the core asserts the internal FRZ signal. When FRZ is asserted the instruction 
cache treats all misses as if they were from cache-inhibited regions and, assuming the 
debug routine is not in the instruction cache, the cache state remains exactly the same. 
When FRzZ is asserted, hits are still read from the array and the LRU bits are updated. 
Therefore, in the simple case of the debug routine it is read from memory like any other miss. 
However, for performance reasons, it might be preferable to run the debug routine from the 
cache. Follow these steps with little variation: 


1. Save both ways of the sets that are needed for the debug routine by reading the tag, 
LRU bit, valid bit, and lock bit values. 
2. Unlock the locked ways in the selected sets. 


3. Use a LOAD & LOCK command to load and lock the debug routine into the instruction 
cache (LOAD & LOCK operates the same when FRZ is asserted). 


4. Run the debug routine. All accesses to it will result in hits. 
After the debug routine has completed, the old state of the instruction cache can be restored 
by following these steps: 

1. Unlock and invalidate all the sets that are used by the debug routine (both ways). 

2. Use aLOAD & LOCK command to restore the old sets. 

3. Unlock the ways that were not previously locked. 

4. To restore the old state of the LRU, make sure the last access is made in the MRU 


way. An access in this description is either LOAD & LOCK or UNLOCK LINE. 
9.9.1 Fetching Instructions From The Development Port 


When the MPC823 is in debug mode all instructions are fetched from the development port, 
regardless of the address generated by the core. Therefore, the instruction cache is 
practically bypassed when the MPC823 is in debug mode. 
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SECTION 10 
DATA CACHE 


The MPC823 data cache is a 1K two-way, set-associative cache. It is organized into 32 sets, 
two lines per set and four words per line. Cache lines are aligned on 4-word boundaries in 
memory and can be used as an SRAM that allows the application to lock critical data 
segments that need a fast and deterministic execution time. Two state bits are included in 
each cache line and implement invalid, modified-valid, and unmodified-valid states of the 
data cache. Cache coherency in a multiprocessor environment is maintained by the 
software and supported by a fast hardware invalidation capability. The cache is designed for 
both writeback and writethrough modes of operation and a least recently used (LRU) 
replacement algorithm is used to select a line when no empty lines are available. 


10.1 FEATURES 


The following is a list of the data cache’s main features: 


e 1K Two-Way, Set Associative, and Physically Addressed 

e Single-Cycle Cache Access On Hit and 1 Clock Latency Added for Miss 
e Four Word Line Size 

e “Critical Word First” and Four Word Burst Line Fill 

e Implements LRU Replacement Policy 

e 32-Bit Interface to Load/Store Unit 

e One-Word Write Buffer 

e Lockable Cache Line Granularity 


¢ Copyback/Writethrough Operation is Programmed Per Memory Management Unit 
Page 


e Coherency is Only Maintained By the Software and No Bus Snooping is Supported 

e Cache Operation is Blocked Under Miss, Until the Critical Word is Delivered to the Core 
e Hit Under Miss Operation 

e Full Data Cache PowerPC™ Control Operations 

e Implementation-Specific Single Operation 
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10.2 ORGANIZATION OF THE DATA CACHE 


The data cache is a 1K two-way, set associative, physically addressed cache that has 
16-byte line and a 32-bit data path to and from the load/store unit, which allows for a 4-byte 
transfer per cycle. 


0 22 23 27 28 «31 
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Figure 10-1. Data Cache Organization 
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ADDRESS [23:27] 


1K 


CACHE 
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SEF 
DECODER 
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Figure 10-2. Cache Data Path Block Diagram 


10.3 PROGRAMMING THE DATA CACHE 


10.3.1 PowerPC Architecture Instructions 
The following PowerPC instructions are supported by the data cache. 


10.3.1.1 POWERPC USER INSTRUCTION SET ARCHITECTURE (BOOK I) 


The data cache supports the sync instruction through a cache pipe clean indication fo the 
core. 
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10.3.1.2 POWERPC VIRTUAL ENVIRONMENT ARCHITECTURE (BOOK Il) 
The data cache supports the following instructions: 


e Data cache block flush (dcbf) 

e Data cache block store (dcbst) 

e Data cache block touch (debt) 

¢ Data cache block touch for store (dcbtst) 
e Data cache block set to zero (dcbz) 


10.3.1.3 PowERPC OPERATING ENVIRONMENT ARCHITECTURE (BOOK lil). The 
data cache supports the dcbi (data cache block invalidate) instruction. 


10.3.2 Implementation-Specific Operations 


The MPC823 data cache includes some extended features in addition to those in the 
PowerPC architecture. The following are implementation-specific operations supported by 


_ the MPC823 data cache: 


¢ Block lock 
e Block unlock 


Invalidate all 

e Unlock all 

e Flush cache line 
° Read tags 

e Read registers 


10.3.3 Special Registers of the Data Cache 
The PowerPC special registers are accessed via the mtspr and mfspr instructions. The 
following registers are used to control the data cache: 

e Data cache control and status register (DC_CSR) 

¢ Data cache address register (DC_ADR) 

e Data cache data register (DC_DAT) — 


These registers are privileged and any attempt to access them while the core is in the 
problem state (MSRppr =1) results in a program interrupt. 
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10.3.3.1 DATA CACHE CONTROL AND STATUS REGISTER. The data cache control 
and status register (DC_CSR) is used to configure and access the status of the data cache. 


DC_CSR | 


pw RESERVED CCER1 | CCER2 | CCER3 RESERVED 
eee 










R 


/W 
568 
eee 
RESERVED 


NOTE: — = Undefined. 
















DEN—Data Cache Enable Status 


This bit is read-only and any attempt to write to it is ignored. Write to the CMD field to enable 
or disable the data cache. 


0 = Data cache is disabled. 
1 = Data cache is enabled. 


DFWT—Data Cache Force Writethrough 


This bit is read-only and any attempt to write to it is ignored. Write to the CMD field to set or 
force writethrough mode. 


0 = Data cache mode determined by memory management unit. 
1 = Data cache is forced writethrough. 


LES—Little-Endian Swap 


Refer to Section 14 Endian Modes for details about how this bit i is used to achieve the 
required endian behavior. This bit is read-only. Write to the CMD field to set or clear 
little-endian swap mode. 


O = Address of the data and the instruction caches is the unchanged address from the 
core. No byte swap is done on the data and instruction caches’ external accesses. 

1 = Address munging performed by the core is reversed before accessing the data 
cache, the instruction cache and storage. Byte swap is performed for the 
instruction and data caches’ external accesses. This bit is a read-only bit and any 
attempt to write to it is ignored. 
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Bits 3, 8, and 9—Reserved 
These bits are reserved and should be set to 0. 


CMD—Command 


The following commands can be written to the CMD field to control and configure the data 
cache. The machine must be in privilege mode (MSRpp=1). 


0000 = Reserved. 

0010 = DATA CACHE ENABLE. 

0100 = DATA CACHE DISABLE. 

0110 = LOCK LINE. 

1000 = UNLOCK LINE. 

1010 = UNLOCK ALL. 

1100 = INVALIDATE ALL. 

1110 = FLUSH DATA CACHE LINE. 

0001 = SET FORCE WRITETHROUGH MODE. 
0011 = CLEAR FORCE WRITETHROUGH MODE. 
0101 = SET LITTLE-ENDIAN SWAP MODE. 
0111 = CLEAR LITTLE-ENDIAN SWAP MODE. 
Others = Reserved. 


CCER1—Data Cache Error Type 1 
This field is sticky and set by the hardware. It is read-only and cleared when read. 


O= No Error. 
1 = Error. 


CCER2—Data Cache Error Type 2 
This field is sticky and set by the hardware. It is read-only and cleared when read. 


O= No Error. 
1 = Error. 


CCER3—Data Cache Error Type 3 
This field is sticky and set by the hardware. It is read-only and cleared when read. 


0= No Error. 
1 = Error. 


Bits 13-31—Reserved 
These bits are reserved and should be set to 0. 
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10.3.3.2 DATA CACHE ADDRESS REGISTER. The data cache address register 
(DC_ADR) contains the address to be used in the command programmed in the CMD field 
of the DC_CSR. It also may contain the internal address for the read tags and register 
operation. 


DC_ADR 










— = Undefined. 





OTE: 


ADR—Address 


This field represents the address to be used in the command programmed in the DC_CSR. 
It is also the internal address used to read tags and registers. 


10.3.3.3 READING THE CACHE STRUCTURES. To read the data stored in the data 
cache tags or registers, follow these steps: 


1. Write to the DC_ADR. This register can also be read for debugging purposes. 
2. Read the DC_DAT register. 
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Data Cache 





The DC_ADR must be configured into the following fields before the internal parts of the 
data cache are read from the DC_DAT register. 


DC_ADR (CACHE READ COMMAND FORMAT 


oo 


RESERVED 


569 


i 


Rae 





Bits O-—17—Reserved 
These bits are reserved and should be set to 0. 


RT—Register or Tag Selection 


Select tag operation. 
Select register operation. 


WAY—Way Selection 


Select Way 0 of the cache array. 
Select Way 1 of the cache array. 


Bits 20—22—Reserved 
This bit is reserved and should be set to 0. 


SET—Set Selection 
This field is used to select the index of the cache array. 


WORD—Word Selection 
This field is used to select a word within a set and way. 


Bits 30-—31—Reserved 
These bits are reserved and should be set to 0. 
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Data Cache 


The register number field specifies the register to be read. The following registers and their 
encoding are supported: 


e Q0x00—Copyback data register 0 
Ox01—Copyback data register 1 


0x02—Copyback data register 2 
0x03—Copyback data register 3 
0x04—Copyback address register 


When reading from the DC_DAT register, the 23 bits of the tag and related information that 
is selected by the DC_ADR are placed in the targeted general-purpose register. The 
following table illustrates the DC_DAT register’s bit layout when reading a tag. Writing to 
DC_DAT is illegal. A write to DC_DAT results in an undefined data cache state. 


DC_DAT (TAG READ FORMAT) 


5 


as 


ee 


eae 


= y 
RESERVED 





NOTE: — = Undefined. 


TAG—Tag Selection 
This field contains the upper 23 bits of the address. 


L—Lock Entry 


0 = Cache entry is unlocked. 
1 = Cache entry is locked. 


LRU—Least Recently Used 


O= This entry is not aged or least-recently used. 
1 = This entry is aged or least-recently used. 


D—Dirty or Clean Cache Line 


0= This entry has not been modified since it was read from memory. 
1 = This entry has been modified since it was read from memory. 
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Data Cache 


V—Valid Cache Line 


O= Entry is not valid. 
1 = Entry is valid. 


Bits 27—31—Reserved 
These bits are reserved and should be set to 0. 


10.4 OPERATING THE DATA CACHE 


The data cache is a three-state design. Two bits are included in each cache line to maintain 
the line’s state information. The status bits keep track of whether or not the line is valid or if 
it has been modified relative to memory. These modes are invalid, modified-valid, and 
unmodified-valid. — | 


10.4.1 Data Cache Read 


There are two possible outcomes of a data cache read: 


e Read Hit—On a cache hit, the requested word is immediately transferred to the 
load/store unit and the LRU state of the set is updated. No state transition occurs and 
the access time is 1 clock (zero wait state). 


e Read Miss—A line in the cache is selected to hold the data that will be fetched from 
memory. The selection algorithm gives first priority to invalid lines and if both lines are 
invalid, the way zero line is selected first. If neither of the two candidate lines in the 
selected set is invalid, then one of the lines is selected by the LRU algorithm for 
replacement. If the selected line is valid-modified (dirty), then it is kept in a special buffer 
to be written out (flushed) to memory or a later time. 


Subsequently, the address of the missed entry is sent to the system interface unit with 
a request to retrieve the cache line. The system interface unit arbitrates for the bus and 
initiates a 4-word burst transfer read request. The transfer begins with the aligned word 
containing the missed data, followed by the remaining word in the line, then by the word 
at the beginning of the line (wraparound). As the missed word is received from the bus, 
it is delivered (forwarded) directly to the load/store unit. When the line has been fully 
received, it is written into the cache. The data cache supports further requests as long 
as they hit in the cache immediately after the arrival of the critical word. 


After the line with the requested data has been brought from memory, the dirty line kept 
in the buffer is sent to the system interface unit to be written out (flushed) to memory. If 
a bus error is detected during the fetch of the missed “critical word”, a machine check 
interrupt is generated. If a bus error occurs on any other word in the line transfer, the 
line is marked invalid. On the other hand, if no bus error is encountered, the cache line 
is marked unmodified-valid. If a bus error is detected during the dirty line flush, a 
machine check interrupt is generated (the dirty line flush error is an imprecise interrupt). 
For more information about reading the address and data of a line, see 

Section 10.3.3.3 Reading the Cache Structures. 
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10.4.2 Data Cache Write 


The cache operates in either writethrough or copyback mode, depending on how the 
memory management unit is programmed. If two logical blocks map to the same physical 
block, it is considered a programming error for them to specify different cache write policies. 


10.4.2.1 COPYBACK MODE 


In copyback mode, write operations do not necessarily update the external memory. For this 
reason, copyback mode is the preferred mode of operation when it is necessary to keep bus 
bandwidth usage and power consumption at a minimum. The possible outcomes of a data 
cache write in copyback mode are: 


e Write Hit to Modified Line—Data is simply written into the cache with no state transition. 
The LRU of the set is updated to point to the way holding the hit data. 


e Write Hit to Unmodified Line—Data is written into the cache and the line is marked 
modified. The LRU of the set is updated to point to the way holding the hit data. 


e Write Miss—A line in the cache is selected to hold the data that is fetched from memory. 
The selection algorithm gives first priority to invalid lines if both lines are invalid the way 
zero line is selected first. If neither of the two candidate lines in the selected set is 
invalid, then one of the lines is selected by the LRU algorithm for replacement. If the 
selected line is valid-modified (dirty), it is kept in a special buffer to be written out 
(flushed) to memory at a later time. 


Subsequently, the address of the missed entry is sent to the system interface unit with 
a request to retrieve the cache line. The system interface unit arbitrates for the bus and 
initiates a 4-word burst transfer read request. The transfer begins with the aligned word 
containing the missed data (the critical word first), followed by the remaining word in the 
line, then by the word at the beginning of the line (wraparound). As the missed word is 
received from the bus, it is merged with the data to be written. When the line has been 
fully received, it is written into the cache. Once the line fill is complete, the new store 
data is written into the cache and the line is marked modified-valid (dirty). At this point, 
if the machine stalls while waiting for the store to complete, execution is allowed to 
resume. The data cache does not support further requests until after the whole line 
arrives. 


After the line with the requested data has been brought from memory, the dirty line kept 
in the buffer is sent to the system interface unit to be written out (flushed) to memory. 
The data cache can support further requests as long as they hit in the cache while 
flushing the dirty line to memory. If a bus error is detected during a fetch of the missed 
line (even on a word not accessed by the load/store unit) the cache line is not modified 
and a machine check interrupt is generated. If a bus error is detected during the dirty 
line flush, a machine check interrupt is generated (the dirty line flush error is an 
imprecise interrupt). For more information about reading the address and data of a line, 
see Section 10.3.1.2 PowerPC Virtual Environment Architecture (Book Il). 
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Data Cache 


10.4.2.2 WRITETHROUGH MODE. In writethrough mode, store operations always update 
memory. This mode is used when external memory and internal cache images must agree. 
It gives a lower worst-case interrupt latency at the expense of average performance (for 
example, if it does not have to do flush accesses). The possible outcomes of a data cache 
write in writethrough mode are: 


e Write Hit—Data is written into both the cache and memory, but the cache state is not 
changed. The LRU of the set is updated to point to the way holding the hit data. If a bus 
error is detected during the write cycle, the cache is still updated and a machine check 
interrupt is generated. 


e Write Miss—Data is only written into memory, not to the cache (write no allocate) and 
no state transition occurs. The LRU is not changed, but if a bus error is detected during 
the write cycle, a machine check interrupt is generated. 


10.4.3 Data Cache Inhibited Accesses 


If the cache access is to a page that has the Cl bit set in the memory management unit, one 
of the following outcomes will occur: 


e Hit to Modified or Unmodified Line—This is considered a programming error if the 
targeted location copy of a load, store, or dcbz instruction to cache inhibit storage is in 
the cache. The result is boundedly undefined. 


e Read Miss—Data is read from memory, but not placed in the cache. The cache’s status 
is unaffected. 


e Write Miss—Data is written through to memory, but not placed in the cache. The 
cache’s status is unaffected. 


10.4.4 Data Cache Freeze 


The MPC823 can be debugged either in debug mode or by a software monitor debugger. 
The data cache is frozen when the FRZ signal is asserted so that the data cache can be 
examined for debugging purposes. For a detailed description of MPC823 debug support 
refer to Section 20 Development Capabilities and Interface. When FRZ is asserted, the 
possible outcomes are: 


e Read Miss—Data is read from memory, but not placed in the cache. The cache’s status 
is unaffected. 


e Read Hit—Data is read from the cache, but LRU is not updated. 
e Write Miss/Hit—Data cache operates in writethrough mode, but LRU is not updated. 


¢ dcbz Instruction Miss/Hit—Data is written into cache and memory, but LRU is not 
updated. 


dcbst/dcbf/dcbi Instructions—The data cache and memory is updated according to 
the PowerPC architecture, but LRU is not updated. 
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10.4.5 Data Cache Coherency 


The MPC823 data cache provides no support for snooping external bus activity. All 
coherency between the internal caches and memory/devices external to the extended core 
must be controlled by the software. In addition, there is no mechanism provided for DMA or 
other internal masters to access the data cache directly. 


10.5 DATA CACHE COMMANDS 


10.5.1 Flushing and Invalidating the Cache 


The MPC823 allows the software to control how the data cache is flushed and invalidated. 
The data cache can be invalidated by writing the UNLOCK ALL and INVALIDATE ALL 
commands to the DC_CSR. The data cache is not automatically invalidated on reset. It must 
be invalidated under software control. The data cache can be flushed by a software loop 
using the dcbst or debf instructions or the implementation-specific CACHE LINE FLUSH 
command. Notice that the PowerPC architecture instructions flush a line indexed by the 
effective address, while the implementation-specific command indexes a line by its physical 
set index within the data cache. 


When flushing must be restricted to a specific memory area or the architecture must be 
compliant, it is recommended that you use the PowerPC architecture instructions. However, 
if the entire data cache must be flushed and there is no concern for compatibility, the 
implementation-specific command is more efficient. If a bus error occurs while executing the 
dcbf and debst instructions or the implementation-specific CACHE LINE FLUSH 
command, the data of the cache line specified by these operations must be retrieved from 
the copyback data registers rather than from the data cache array. 


10.5.2 Enabling and Disabling the Cache 


The data cache can be enabled or disabled by writing the DATA CACHE ENABLE and 
DATA CACHE DISABLE commands to the DC_CSR. In the disabled state, the cache tag 
state bits are ignored and all accesses are propagated to the bus as single beat 
transactions. The default after the reset state of the data cache is disabled. Disabling the 
data cache does not affect the data address translation logic and translation is still controlled 
by the MSRp,p bit. Any write to the DC_CSR must be preceded by a sync instruction. This 
prevents the data cache from being disabled or enabled in the middle of a data access. 
When the data cache generates an interrupt as a result of a bus error on the COPYBACK 
or implementation-specific CACHE LINE FLUSH command, it enters the disable state. 
Operation of the cache when it is disabled is similar to cache-inhibit operation. 


10.5.3 Locking and Unlocking the Cache 


Each line of the data cache can be independently locked by writing the LOCK LINE 
command to the DC_CSR. Replacement line fills are not performed to a locked line. A flush 
or invalidation of a locked line cache is ignored by the data cache. Any write to the DC_CSR 
must be preceded by a sync instruction, which prevents a cache from being locked during 
a line fill. Use the UNLOCK LINE or UNLOCK ALL commands to unlock the cache. 
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10.5.4 Data Cache Instructions 


10.5.4.1 dcbi, dcbst, dcbf AND dcbz INSTRUCTIONS 

The dcbz, dcbi, dcbst, and debf instructions operate on a block basis of cache line, which 
is 16 bytes (4 words) long. A data TLB miss exception is generated if the effective address 
of one of these instructions cannot be translated and data address relocation is enabled. — 


10.5.4.2 TOUCH. The debt and debtst instructions of the MPC823 operate on a block 
basis of cache line, which is 16 bytes (4 words) long. Touch instructions initiate bus transfers 
to bring in a cache line of data from memory. They become no operation instructions if the 
effective address cannot be translated when the memory management unit is enabled. 


10.5.4.3 STORAGE SYNCHRONIZATION/RESERVATION. The MPC823 does not 
support the multimaster storage protocol. 


10.5.5 Data Cache Read 


To allow debug and recovery actions, the MPC823 allows the content of the tags array as 
well as the last copyback address and data buffers to be read. See Section 10.3.3 Special 
Registers of the Data Cache for details. This operation is privileged and any attempt to 

perform it when the core is in the problem state (MSRp,p =1) results in a program interrupt. 
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SECTION 11 
MEMORY MANAGEMENT UNIT 


The MPC823 implements a virtual memory management scheme that provides cache 
control, storage access protection, and effective-to-real address translation. This 
implementation includes separate instruction and data memory management units. The 
MPC823 memory management unit is compliant with the PowerPC Microprocessor Family: 
The Programming Environment for 32-Bit Microprocessors manual in relation to the 
supported attributes, except that two new modes of operation have been added: 


¢ PowerPC™ mode with extended encoding 
e Domain manager mode 
Available protection granularity sizes are page (4K, 16K, 512K, or 8M) or 1K subpage 
(1K subpage resolution is supported for 4K pages only). Hereafter, the prefix Mx_ appears 


before a memory management unit control register name that corresponds to both the 
instruction and data cache conditions. 


11.1 FEATURES 


The following is a list of the memory management unit’s main features: 


e 8-Entry Fully Associative Data and Instruction Translation Lookaside Buffers (TLBs) 
e Multiple Page Size Support 

¢ High Performance 

¢ Supports Maximum of 16 Virtual Address Spaces 


Supports 16 Access Protection Groups 


Each Entry Can Be Programmed to Match Problem Accesses, Privileged Accesses, or 
Both 


PowerPC MSRi,q and MSRpr Controls Memory Management Unit Translation and 
Protection 


e Supports PowerPC tlbie and tlbia Instructions. No tlbsync Instruction Is Supported, 
But It ls Implemented As a NOP Instruction. 


e PowerPC mtspr/mfspr Instructions To and From the Implementation-Specific 
Special-Purpose Registers Can be Used for Programming 


A Scratch Register Is Available for Software Tablewalks 


Designed for Minimum Power Consumption | 
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Memory Management Unit 


11.2 ADDRESS TRANSLATION 


The MPC823 core generates 32-bit effective addresses and, when enabled, the memory 
management unit translates the effective address to a real address that is used for cache or 
memory access. If disabled, the effective address is passed as the real address to the 
memory, which bypasses the appropriate translation lookaside buffer. When the memory 
management unit is enabled, the effective address is used to locate a TLB entry if found or 
hit, which will then provide the real address mapping and storage attributes. For 
performance reasons, a translation lookaside buffer is implemented in each hardware cache 
to hold recently used address translations. In the MPC823, the table lookup and TLB reload 
are performed by a software routine with little hardware assistance. This partition simplifies 
the hardware and gives the system the opportunity to choose the translation table structure. 


A TLB hit in multiple entries is avoided during the TLB reload phase. The TLB logic 
recognizes that the effective page number (EPN) currently loaded into the translation 
lookaside buffer overlaps another EPN. At least when taking into account the page sizes, 
subpage validity flags, problem/privileged state, address space ID (ASID), and the SH 
values of the TLB entries. When such an event occurs, the current EPN is written into the 
translation lookaside buffer and the entry of the other EPN is invalidated from the translation 
lookaside buffer. 


The memory management unit supports a multiple virtual address space model and, when 
enabled, each translation is associated with an ASID. In this case, for the translation to be 
valid, its ASID must be equal to the current address space ID (CASID) that is in effect when 
an access is performed. 


11.2.1 Translation Lookaside Buffer Operation 


Two translation lookaside buffers are provided in the MPC823—one for instruction fetches 
and one for data accesses. The translation lookaside buffer contains pointers to pages in 
the real memory where data is indexed by the effective page number and it can hold entries 
with different page sizes. The entry page size controls the number of effective address bits 
to be compared and the number of least-significant effective address bits that remain 
untranslated and passes them as least-significant real address bits. 


For a 4K page size, four subpage validity flags are supported, thus allowing any combination 
of 1K subpages to be mapped. For any other page size, all of these flags should have the 
same value. Programming pages other than 4K pages with different valid bits is considered 
a programming error. The subpage validity flags can be manipulated to implement effective 
page sizes of 1K, 2K, 3K, 4K, or any other combination of 1K subpages. However, subpages 
of an effective page frame must all map to the same real page. During the translation 
process, the effective address, the processor problem state (MSRppr), and CASID are 
provided to the translation lookaside buffer. See Figure 11-1 for details. In the translation 
lookaside buffer, the effective address and CASID are compared with the EPN and ASID of 
each entry. The CASID is only compared when the matching entry was programmed as 
nonshared. See Section 11.6.1.6 MMU Instruction Real Page Number Register and 
Section 11.6.1.7 MMU Data Real Page Number Register for details. 
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A successful TLB hit occurs if the incoming effective address matches the EPN stored ina 
valid TLB entry and the CASID value stored in the M_CASID register matches the entry’s 
ASID field. At the same time, the subpage validity flag is set for the subpage pointed to by 
the incoming effective address. If a hit is detected, the content of the real page number is 
concatenated with the appropriate number of least-significant bits from the effective address 
to form the real address that is then sent to the cache and memory system. 


11.3 PROTECTION 


Access control is assigned on a page-by-page basis and any further manipulation is 
conducted on a group basis. 


32-BIT EFFECTIVE 
CASID ADDRESS 

(FROM M_CASID) 

MSRPR 


12 


20 
PAGE BYE.) aneaeee © 







IMPLEMENTATION SPECIFIC 
TLB MISS INTERRUPTS — 
TO CORE 


PAGE PROTECTION 









FREE ACCESS 






PROTECTION 


GROUP NUMBER IMPLEMENTATION 


: SPECIFIC 
ERROR INTERRUPTS 
TO CORE 


REAL PAGE NUMBER { BYTE 


NO ACCESS 


TRANSLATION | TR ANSLATION PROTECTION 
ENABLED Sy, ENABLED LOOKUP \ 
: EXCEPTION 
LOGIC 


32-BIT REAL ADDRESS 


Figure 11-1. Block Diagram of Effective-to-Real Address Translation For 4K Pages 
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‘Memory Management Unit 


Each TLB entry holds an access protection group (APG) number. When a match is detected, 
the value of the matched entry’s APG is used to index a field in the access protection register 


that defines access control for the translation. The access protection register contains 16 
fields. The field content is used according to the group protection mode. In the PowerPC 
-mode, each field holds the Kp and Ks bits of a corresponding segment register. To be | 


consistent with the PowerPC Microprocessor Family: The Programming Environment for 
32-Bit Microprocessors manual, the APG value should match the four most-significant bits 
of the effective page number. In domain manager mode, each field holds override 
information over the page protection setting. No override, no access override, and free 
access override modes are all supported. 


11.4 STORAGE CONTROL 


The memory management unit can be used to map a block of memory in different access 
modes. Each page can have different storage control attributes. The MPC823 supports 
cache inhibit, writethrough, and guarded attributes, but not the memory coherence attribute. 
A page that needs to be memory coherent must be programmed cache-inhibited. Refer to 
the definition of these attributes in the PowerPC Microprocessor Family: The Programming 
Environment for 32-Bit Microprocessors manual. The effects of the cache-inhibit and 
writethrough attributes in the MPC823 are described in Section 9 Instruction Cache. 


The guarded attribute is used to map I/O devices that are sensitive to speculative accesses. 
An attempt to access a page marked guarded with the guarded bit asserted forces the 
access to stall until the access is nonspeculative or canceled by the core. Fetching from a 
guarded storage is prohibited and if it is attempted an implementation-specific instruction 
storage interrupt is generated. When MSRijp or MSRo, for instruction or data address 
translation are negated, default attributes are used. See Section 11.6.1.1 MMU Instruction 
Control Register and Section 11.6.1.2 MMU Data Control Register for details. 


The MPC823 does not generate an exception for a reference bit update because there is no 
entry for a reference bit in the translation lookaside buffer. The change bit updates are 
implemented by the software, but the hardware treats the change bit as a write-protect 
attribute. Therefore, if you try to write to a page marked unmodified, that entry is invalidated 
and an implementation-specific data TLB error interrupt is generated. | 
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11.5 TRANSLATION TABLE STRUCTURE 


The MPC823 memory management unit includes special hardware to assist in a two-level 
software tablewalk. Other table structures are not precluded. Figure 11-2 and Figure 11-3 
illustrate the two levels of translation table structures supported by MPC823 special 
hardware. When MD_CTRyway = 1, the tablewalk begins at the level one base address in 
the M_TWB register. The level one table is indexed by the ten most-significant bits of the 
effective address to get the level one page descriptor. For 8M pages, there must be two 
identical entries in the level one table for either Bit 9 =O or Bit 9 =1. See Table 11-2 for more 
information. The level two base address from the level one descriptor is indexed by the next 
ten least-significant bits to find the level two page descriptor. For pages larger than 4K, the 
entry in the level two table must be duplicated according to the page size. See Table 11-3 
for more information. 


During address translation by the memory management unit, the most-significant bits of the 
missed effective address are replaced by the real page address bits from the level two page 
descriptor. The number of replaced bits depends on the page size. The rest of the real 
address bits are taken directly from the effective address. When MD_CTRywam = 0, the 
tablewalk begins at the level one base address placed in the M_TWB register. The level one 
table is indexed by the 12 most-significant bits of the effective address to get the level one 
page descriptor. For 8M pages, there must be eight identical entries in the level one table 
for bits 9-11 of the effective address. The level two base address from the level one 
descriptor is indexed by the next ten least-significant bits to find the level two page 
descriptor. For pages larger than 1K, the entry in the level two table must be duplicated 
according to the page size. 
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Memory Management Unit 


EFFECTIVE ADDRESS 
0 9 10 19 20 31 


0 . a 19 | LEVEL1INDEX | LEVEL 2 INDEX PAGE OFFSET 
LEVEL ONE TABLE POINTER ~ | Ld 


20 | 10. 


| LEVEL ONE TABLE BASE ‘| LEVEL 1 INDEX 00 | 












LEVEL ONE TABLE 


LEVEL ONE DESCRIPTOR 0 
| LEVEL ONE DESCRIPTOR 1 




















20 [LEVEL ONE DESCRIPTOR 1023 _| . ae 
~ LEVEL ONE DESCRIPTOR 1023 Gooner 
| 19=FOR 512K 
23-FOR 8M 
LEVEL TWO TABLE BASE LEVEL 2 INDEX 00 | 
LEVEL TWO TABLE 
LEVEL TWO DESCRIPTOR 0 
LEVEL TWO DESCRIPTOR 1 
20-FOR 4K LEVEL TWO DESCRIPTOR 1023 
18-FOR 16K 
13-FOR 512K 
9-FOR 8M 


REAL PAGE ADDRESS PAGE OFFSET 


REAL ADDRESS 
Figure 11-2. Two Level Translation Table When MD_CTR(TWAM) = 1 


11-6 MPC823 USER’S MANUAL MOTOROLA 


Memory Management Unit 


EFFECTIVE ADDRESS 
0 11 12 21 22 31 


0 17 LEVEL 1 INDEX LEVEL 2 INDEX PAGE OFFSET 
LEVEL ONE TABLE POINTER a 


18 12 


LEVEL ONE TABLE BASE LEVEL 1 INDEX 00 | 



















LEVEL ONE TABLE 


LEVEL ONE DESCRIPTOR 0 
LEVEL ONE DESCRIPTOR 1 








LEVEL ONE DESCRIPTOR N 





20 12-FOR 1K 
aaa 
14-FOR 16K 
19-FOR 512K 
23-FOR 8M 


LEVEL TWO TABLE BASE LEVEL 2 INDEX 00 | 


LEVEL TWO TABLE 


LEVEL TWO DESCRIPTOR 0 
LEVEL TW PTOR 1 


LEVEL TWO DESCRIPTOR N 
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20-FOR 1k 
20-FOR 4K 
18-FOR 16K 
13-FOR 512K 
9-FOR 8M 


REAL PAGE ADDRESS PAGE OFFSET 


| | REAL ADDRESS 
Figure 11-3. Two Level Translation Table When MD_CTR(TWAM) = 0 
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During the memory management unit’s address translation, the most-significant bits of the 
missed effective address are replaced by the real page address bits from the level two page 
descriptor. The number of replaced bits depends on the page size. The rest of the real 
address bits are taken directly from the effective address. See Table 11-1 for details. 


Table 11-1. Number of Effective Address Bits Replaced 
By Real Address Bits 





Table 11-2. Number of Identical Entries Required in 
the Level One Table 
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Table 11-3. Number of Identical Entries Required in 
the Level Two Table 
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11.5.1 Level One Descriptor 


The following table describes the hardware-assisted level one descriptor format that 
minimizes the software tablewalk routine. 


LEVEL ONE DESCRIPTOR FORMAT 





SYSTEM MEMORY XXXXX0000 


cy 
a ee ee (es et eS 
aw [aw 











aw zl 
SYSTEM MEMORY XXXXX002 


NOTE: — = Undefined. The default values depend on the state of system memory. 


L2BA—Level 2 Table Base Address 


This field contains a pointer to a base address of the level 2 table. Bits 18 and 19 are only 
used when MD_CTR way = 1. Otherwise, they should be set to 0. 


Bits 20—22—Reserved 
These bits are reserved and should be set to 0. 


APG—Access Protection Group 


This field contains access protection for the entire memory segment associated with this 
entry of the table. 


G—Guarded Storage Attribute for Entry 


0 = Unguarded storage. 
1 = Guarded storage. 


PS—Page Size Level One 


00 = Small (4K or 16K). 
O1 = 512K. 

11 = 8K. 

10 = Reserved. 


WT—Writethrough Attribute for Entry 


0 = Copyback cache policy region (default). 
1 = Writethrough cache policy region. 
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V—Valid 
0 
1 


Segment is not valid. 
Segment is valid. 


11.5.2 Level Two Descriptor 


The following table describes the hardware-assisted level two descriptor format that 
minimizes the software tablewalk routine. 


LEVEL TWO DESCRIPTOR FORMAT 


SYSTEM MEMORY 


Lensentinndabtidiay 


RPN—Real Page Number 
This field contains the physical address of the page mapped in by this entry. 


PP1—Protection for the First 1K Subpage in a 4K Page 


This field contains protection code for the first subpage in a 4K page. Depending on Bit 22 
of the PP2 field, the same protection code has different protection schemes. 








4K PAGES WITH 1K RESOLUTION PROTECTION 





INSTRUCTION PAGES DATA PAGES 


PRIVILEGED MODE PRIVILEGED MODE 
[—nescasss | _Nowmnes | _Nowmoss | Nocone 
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PAGES OVER 4K WITH 4K RESOLUTION PROTECTION (EXTENDED ENCODING) 


PP1 INSTRUCTION PAGES DATA PAGES 
SETTING 


[co | _Nowscess | _Nowmress | _nowsass | _Roacrmss 
















PAGES OVER 4K WITH 4K RESOLUTION PROTECTION (POWERPC ENCODING) 


PP4 INSTRUCTION PAGES DATA PAGES 
SETTING 


[co [Seno | _srearabe [| __Reosony [| Rrecon 


PP2—Protection for a Second 1K Subpage in a 4K Page 


This field contains a protection code for the second subpage in a 4K page. Depending on 
the encoding mode, this field has different meanings. 


















4K PAGES WITH 1K RESOLUTION PROTECTION 


PP2 INSTRUCTION PAGES DATA PAGES 
SETTING 


a 
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PP3—Protection for the Third 1K Subpage in a 4K Page 


This field contains protection code for the third subpage in a 4K page. Depending on the 
encoding mode, this field has different meanings. 













4K PAGES WITH 1K RESOLUTION PROTECTION 


PP3 INSTRUCTION PAGES DATA PAGES 
SETTING 


a 
















PAGES OVER 4K WITH 4K RESOLUTION PROTECTION | 


PP3 SETTING CASE: Mx_CTR (PPCS) = 0 
First subpage not valid 


Second subpage not valid | 
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PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 


a 


PP4—Protection for the Fourth 1K Subpage in a 4K Page 


This field contains protection code for the fourth subpage in a 4K page. Depending on the 
encoding mode, this field has different meanings. 









4K PAGES WITH 1K RESOLUTION PROTECTION 


INSTRUCTION PAGES DATA PAGES 













PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 


PP4 SETTING CASE: Mx_CTR (PPCS) =0 
Third subpage not valid 
Third subpage valid 
1 









Fourth subpage not valid 
Fourth subpage valid 
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PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 


a 


LPS—Large Page Size 
This bit must be set to 0 for 1K resolution protection. 






O= 1Kor 4K. 
1= 16K. 


SH—Shared Page 


O= This entry matches only if the ASID field in the TLB entry matches the value of the 
M_CASID register. 
1 = ASID comparison is disabled for the entry. 


Cl—Cache Inhibit 


This bit is the cache-inhibit attribute for the entry. Setting this bit will inhibit cache fill for 
accesses to this page. 


V—Valid 
This is the page valid bit. Setting this bit indicates the page is valid or resident in the memory 
(for demand page memory management). 
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11.6 PROGRAMMING THE MEMORY MANAGEMENT UNIT 


The memory management unit implements specific operations using control and status 
registers, which can be accessed with the PowerPC mtspr/mfspr instructions. In addition, 
the PowerPC tlbie and tibia architecture instructions are supported. The memory 
management unit registers should be accessed when both MSR), =0 and MSRpp =0. No 
similar restriction exists for the tlbie and tlbia instructions. 










INSTRUCTION MMU REGISTERS \ DATA MMU REGISTERS 

\ 
\ 

CONFIGURATION REGISTERS: . 
\ 
. 
\ 

MI_CTR Instruction MMU Control \ MD_CTR Data MMU Control 

MI_AP Instruction MMU Access Protection N MD_AP Data MMU Access Protection — 


\ 
M_CASID Current Address Space ID 


TABLE WALK REGISTERS: 






| y 4 


MI_EPN Instruction MMU Effective Address MD_EPN Data MMU Effective Address 


ye hf A 


MI_TWC__ | Instruction MMU Table Walk Control | 8 MD_TWC Data MMU Table Walk Control 


MI_RPN Instruction MMU Real Address 






Ooo hf A 


a 
ae 
“Ss. 
7s 
i 
oe 
a 
za. 
a 
— 
> 
are 
a?) 
= 
Lu 
= 


MD_RPN Data MMU Real Address 


M_TWB MMU Table Walk Base 


M_TW MMU Table Walk Scratch 






DEBUG REGISTERS: \ 
\ 
N | 

Mi_DCAM Instruction MMU Debug CAM N MD_DCAM Data MMU Debug CAM 
\ 

Mi_DRAMO Instruction MMU Debug RAMO N MD_DRAMO Data MMU Debug RAMO 
\ 
\ 

MlI_DRAM1 Instruction MMU Debug RAM1 \ MD_DRAM1 Data MMU Debug RAM1 
\ A 
\ 
N 





Figure 11-4. Organization of the Memory Management Unit Registers 
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11.6.1 Control Registers 


11.6.1.1 MMU INSTRUCTION CONTROL REGISTER. The MMU instruction control 
register (MI_CTR) is a special register that is used to control the operation of the instruction 
memory management unit. | | | 


MI_CTR 


eS 


RsVa2l PPCS | RESERVED 


_ 


- RESERVED ITLB_INDX 
mm em 


(IMMR & OxFFFFO000) + 0x784 





GPM—Group Protection Mode 


O = PowerPC mode. 
1 = Domain manager mode. 


PPM—Page Protection Mode 


O = Page resolution protection. | 
1 = 1K resolution protection for a 4K page. 


CIDEF—CI Default 


Default value for instruction cache-inhibit attribute when the instruction MMU is disabled 
(MSRip = 0 - , 


Bits 3 and 5—Reserved 
These bits are reserved and should be set to 0. Ignored on write and returns a O on read. 


RSV2I—Reserve Two Instruction TLB Entries 


0 = ITLB_INDX decremented modulo 8. 
1 = ITLB_INDX decremented modulo 6. 


PPCS—Privilege/Problem State Compare Mode 


0 = Ignore problem/privilege state during address compare. 
1 = Consider problem/privilege state according to MI_RPN[24:27]. 


Bits 7-20—Reserved | | _& | ey 
These bits are reserved and should be set to 0. Ignored on write and returns a O on read. 
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ITLB_INDX—Instruction TLB Index 


This field acts as a pointer to the instruction TLB entry to be loaded. It is automatically 
decremented at every instruction translation lookaside buffer update. | 


Bits 24-31—Reserved 
These bits are reserved and should be set to 0. Ignored on write and returns a O on read. 


11.6.1.2 MMU DATA CONTROL REGISTER. The MMU data control register (MD_CTR) is 
a special register that is used to control the operation of the data memory management unit. 


MD_CTR 







CIDEF | WTDEF } RSV2D PPCS RESERVED 
Ba re 
(IMMR & OxFFFFO000) + 0x792 


cna 


RESERVED DTLB_INDX RESERVED 


(IMMR & OxFFFFO000) + 0x792 | 


GPM—Group Protection Mode 


O = PowerPC mode. 
1 = Domain manager mode. 


















PPM—Page Protection Mode 


O = Page resolution protection. 
1 = 1K resolution protection for a 4K page. 


Lu 
= 
Lu 
<>) 
rs 
=: 
= 
> 
ro) o 
— 
Lu 
= 


® 


CIDEF—CI Default 


This bit is the data cache attributes default value when the data MMU is disabled 
(MSRopp = 0). 





WTDEF—WT Default 

This bit is the data cache attributes default value when the data MMU is disabled 
(MSRopre — 0). 

RSV2D—Reserve Two Data TLB Entries 


0 = DTLB_INDX decremented modulo 8. 
1 = DTLB_INDX decremented modulo 6. 
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TWAM—Tablewalk Assist Mode : _ | 


0 = 1K subpage hardware assist. 
1 = 4K page hardware assist. 


PPCS—Privilege/Problem State Compare Mode 


0 = Ignore problem/privilege state during address compare. 
1 = Consider problem/privilege state according to MD_RPN[24:27]. 


Bits 7—20—Reserved 
These bits are reserved and should be set to 0. Ignored on write and returns a 0 on read. 


ITLB_INDX—Instruction TLB Index 


This field acts as a pointer to the data TLB entry to be loaded. It is automatically 
decremented at every data translation lookaside buffer update. 


Bits 24-31—Reserved 
These bits are reserved and should be set to 0. Ignored on write and returns a O on read. 


11.6.1.3 MMU CURRENT ADDRESS SPACE ID REGISTER. The MMU current address 
_ space ID (M_CASID) register is used to compare the current effective address with the ASID 
field in the TLB entry when searching for a matching entry. 


M_CASID 


2s eee 


RESERVED | CASID 
er 


(IMMR & OxFFFF0000) + 0x793 


= 
m 
= 
2) 
= 5) 
< 
= 
> 
= 
> 
P) 
mi 
= 
m 
= 
—| 





NOTE: — = Undefined. 


Bits O0-27—Reserved — : “oe 
These bits are reserved and should be set to 0. Ignored on a write. 


CASID—Current Address Space ID 
This field is compared to the ASID field of a TLB entry to qualify a match. 
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11.6.1.4 MMU INSTRUCTION EFFECTIVE PAGE NUMBER REGISTER. The MMU 
instruction effective page number (MI_EPN) register contains the effective address to be 
loaded into a TLB entry. 


Mi_EPN 


alas vee! ) + 0x787 





(IMMR & OxFFFFO000) + 0x787 


NOTE: — = Undefined. 


EPN—Effective Page Number for the TLB Entry 
This field is the effective address default value of the last instruction TLB miss. 


Bits 20-21 and 23—27—Reserved 
These bits are reserved and should be set to 0. Ignores on write and returns a O on read. 


EV—TLB Entry Valid Bit 
This bit is set to 1 on every instruction TLB miss. 


O= The TLB entry is invalid. 
1 = The TLB entry is valid: 


es 
Zz. 
iw 
= 
Lit 
OS 
= 
z 
<— 
= 
> 
cc. 
Oo 
= 
Lu 
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ASID—Address Space ID 


This field represent the address space ID of the instruction TLB entry to be sonenred with 
the CASID field of the M_CASID register. 


® 
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11.6.1.5 MMU DATA EFFECTIVE PAGE NUMBER REGISTER. The MMU data effective 
page number (MD_EPN) register contains the effective address to be joaaga into a eae 
entry. . 


MD_EPN 


(IMMR & OxFFFFO000) + 0x795 


(IMMR & OxFFFFO000) + 0x795 





NOTE: — = Undefined. 





EPN—Effective Page Number for Entry 
The default value is the effective address of the last data TLB miss. 


EV—TLB Entry Valid 
This bit is set to 1 on.a data TLB miss. 


0 
y 


The data TLB entry is invalid. 
The data TLB entry is valid. 


Bits 23—-27—Reserved 
These bits are reserved and should be set to 0. Ignores on write and returns a 0¢ on read. 


AS|ID—Address Space ID 


This field is the address space IDs of the TLB entry to. be ee with ihe CASID field of 
the M_CASID register. 
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11.6.1.6 MMU INSTRUCTION REAL PAGE NUMBER REGISTER. The MMU instruction 
real page number (MI_RPN) register contains the physical address and the storage 
attributes of an entry to be loaded into a translation lookaside buffer. This register should be 
written after the MI_LEPN and MI_TWC registers are written. 


Mi_RPN 








(IMMR & OxFFFF0000) + 0x790 


NOTE: — = Undefined. The default values depend on the state of system memory. 


_ RPN—Real Page Number | 
These bits are the most-significant bits of the page’s physical address. 


PP1—Protection for the First 1K Subpage in a 4K Page 


This field contains protection code for the first subpage in a 4K page. Depending on Bit 22 
of the PP2 field, the same protection code has different protection schemes. 






4K PAGES WITH 1K RESOLUTION PROTECTION 


PP1 INSTRUCTION PAGES ~ 
SETTING 
PRIVILEGED MODE PROBLEM MODE 
ae 
Se 


Executable Executable 
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PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 
(EXTENDED ENCODING) 










PP1 INSTRUCTION PAGES 


SETTING 
ee 







PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 
(POWERPC ENCODING) 


PP1 INSTRUCTION PAGES 
SETTING 
PRIVILEGED MODE PROBLEM MODE 
a 
Executable Executable 


PP2—Protection for a Second 1K Subpage in a 4K Page 


This field contains a protection code for the second subpage in a 4K page. Depending on 
the encoding mode, this field has different meanings. 
















4K PAGES WITH 1K RESOLUTION PROTECTION 


PP2 INSTRUCTION PAGES 
SETTING |- 
PRIVILEGED MODE PROBLEM MODE 
[00 [_Noaccess | —Noaces— 
Executable Executable 





2am 
oA 
<= 

: ites Se 
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PP2 SETTING PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 


PP1 contains PowerPC encoding 


PP1 contains Extended Encoding 
Page is writable 


Page is write-protected 





PP3—Protection for the Third 1K Subpage in a 4K Page 


This field contains protection code for the third subpage in a 4K page. Depending on the 
encoding mode, this field has different meanings. 


4K PAGES WITH 1K RESOLUTION PROTECTION 


PP3 INSTRUCTION PAGES 


SETTING 
[to [_Noessess [| _Novones 












PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 





PP3 SETTING CASE: MI_CTR (PPCS) =0 





Ox First subpage not valid 


First subpage valid 
Second subpage not valid _ 
Second subpage valid | 
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PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 


PP3 SETTING | CASE: MILCTR(PPCS)=1 _ 
No hit for any state 
Hit only for problem accesses 
Hit only for privilege accesses 


Hit for both problem and privilege accesses 





PP4—Protection for the Fourth 1K Subpage in a 4K Page 


This field contains protection code for the fourth subpage in a 4K page. Depending on the 
encoding mode, this field has different meanings. 






4K PAGES WITH 1K RESOLUTION PROTECTION 














_ PP4 INSTRUCTION PAGES 


SETTING 
[co | _Noesseos | Noone 











PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 


PP4 SETTING | | CASE: MI_CTR (PPCS) =0 
Ox 


Third subpage not valid 

















Third subpage valid 


Fourth subpage not valid 
Fourth subpage valid 
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PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 


A ST — | — CATE 


LPS—Large Page Size 
This bit must be set to 0 for 1K resolution protection. 










O= 1Kor 4K. 
1= 16K. 


SH—Shared Page 
O= This entry matches only if the ASID filed in the TLB entry matches the value of the 


M_CASID register. 
1 = ASID comparison is disabled for the entry. 


Cl—Cache Inhibit 
This bit is the cache-inhibit attribute for the TLB entry. 


V—Valid 
This bit indicates that a TLB entry is valid. 
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11.6.1.7 MMU DATA REAL PAGE NUMBER REGISTER. The MMU data real page 
number (MD_RPN) register contains the physical address and the storage attributes of an 
entry to be loaded into a translation lookaside buffer. This register should be written after the 
MD_EPN and MD_TWC registers. | 


MD_RPN 


| | (IMMR & OxFFFF0000) + 0x798 





(IMMR & OxFFFFO000) + 0x798 


NOTE: — = Undefined. The default values depend on the state of system memory. 


RPN—Real Page Number | 
These bits are the most-significant bits of the page’s physical address. 


PP1—Protection for the First 1K Subpage in a 4K Page 


This field contains protection code for the first subpage in a 4K page. Depending on Bit 22 — | 
of the PP2 field, the same protection code has different protection schemes. | 






4K PAGES WITH 1K RESOLUTION PROTECTION 


PP1 DATA PAGES 
SETTING 
PRIVILEGED MODE PROBLEM MODE 
[co |_Nowssess | _Noscunes 











—— 
2m 
i 
) 
= 8] 
~< 
= 
> 
=— 
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mm 
= 
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= 
Cm | 
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PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 
(EXTENDED ENCODING) 


PP1 DATA PAGES 


SETTING 
ee 


PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 
(POWERPC ENCODING) 
DATA PAGES 
PRIVILEGED MODE PROBLEM MODE 
Read-only Read-only 


PP2—Protection for a Second 1K Subpage in a 4K Page 


This field contains a protection code for the second subpage in a 4K page. Depending on 
the encoding mode, this field has different meanings. 









4K PAGES WITH 1K RESOLUTION PROTECTION 


PP2 DATA PAGES 
SETTING 
PRIVILEGED MODE PROBLEM MODE 
ae a 
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PP2 SETTING PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 
Ox 





PP1 contains PowerPC encoding 








PP1 contains Extended Encoding 








Page is writable 






Page is write-protected 


PP3—Protection for the Third 1K Subpage in a 4K Page 


This field contains protection code for the third subpage in a 4K page. Depending on the 
encoding mode, this field has different meanings. 


4K PAGES WITH 1K RESOLUTION PROTECTION 


PP3 DATA PAGES 
SETTING 
PRIVILEGED MODE PROBLEM MODE 
Read/Write 





| PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 








PP3 SETTING CASE: MD_CTR (PPCS) = 0 











Ox First subpage not valid 








First subpage valid 
Second subpage not valid 
Second subpage valid 
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PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 


PP3 SETTING CASE: MD_CTR (PPCS) = 1 


No hit for any state 


Hit only for problem accesses 


Hit only for privilege accesses 


Hit for both problem and privilege accesses 





PP4—Protection for the Fourth 1K Subpage in a 4K Page 


This field contains protection code for the fourth subpage in a 4K page. Depending on the 
encoding mode, this field has different meanings. 











4K PAGES WITH 1K RESOLUTION PROTECTION 






PP4 DATA PAGES 


SETTING 
[we _Neacons | Noes 



















PAGES OVER 4K WITH 4K RESOLUTION PROTECTION 





PP4 SETTING 





CASE: MD_CTR (PPCS) = 0 











Ox Third subpage not valid 








1x Third subpage valid 
0 


Fourth subpage not valid 
Fourth subpage valid 
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Memory Management Unit 





a 


LPS—Large Page Size 
This bit must be set to 0 for 1K resolution protection. 






O= iKor 4K. 
1= 16K. 


SH—Shared Page 
0 = This entry matches only if the ASID filed in the TLB entry matches the value of the 


M_CASID register. | 
1 = ASID comparison is disabled for a TLB entry. 


Cl—Cache Inhibit 
This bit is the cache-inhibit attribute for a TLB entry. 


V—Vailid 
This bit indicates that a TLB entry is valid. 
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11.6.1.8 MMU INSTRUCTION ACCESS PROTECTION REGISTER. The MMU instruction 
access protection (MI_AP) register contains the access protection group lor the instruction 
memory management unit. 


Mi_AP 


ene & EE ee + oe? 


GP9 GP10 GP11 GP12 GP13 GP14 GP15 


eae a 


(IMMR & OxFFFFO000) + 0x786 


NOTE: — = Undefined. 


GPx—Group Protection 
In domain manager mode, these bits have the following settings. 


00 = No access. 

01 = Client-access permission defined by page protection bits. 
10 = Reserved. 

11 = Manager-free access. 


In PowerPC mode, the GP bits have these settings and are privilege and problem state 
(Ks and Kp) in the PowerPC Microprocessor Family: The Programming Environment for 
32-Bit Microprocessors manual: 


00 = All accesses are considered privileged. 

01 = Access permission defined by page protection bits. 
10 = Problem and privileged interpretation is swapped. 
11 = All accesses are considered problem. 
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11.6.1.9 MMU DATA ACCESS PROTECTION REGISTER. The MMU data access 
protection (MD_AP) register contains the access protection group for the data memory 
management unit. 


MD_AP 





pap et ee 1 et 


(IMMR & OxFFFFO000) + 0x794 





NOTE: — = Undefined. 


GPx—Group Protection 
In domain manager mode, these bits have the following settings. 


OO = No access. 

01 = Client-access permission defined by page protection bits. 
10 = Reserved. 

11 = Manager-free access. 


In PowerPC mode, the GP bits have these settings and are privilege and problem state 
(Ks and Kp) in the PowerPC Microprocessor Family: The Programming Environment for 
32-Bit Microprocessors manual: 


00 = All accesses are considered privileged. | 
01 = Access permission defined by page protection bits. 
10 = Problem and privileged interpretation is swapped. 
11 = All accesses are considered problem. 
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11.6.1.10 MMU INSTRUCTION TABLEWALK CONTROL REGISTER. The MMU 
instruction tablewalk control (MI_TWC) register contains the access protection group and 
page size of the entry to be loaded into the translation lookaside buffer. 


MiI_TWC 












RESERVED 
(IMMR & OxFFFFO000) + 0x789 


a ee eee 
ne eee ee ee eee 


NOTE: — = Undefined. . 










RESERVED 






Bits 0-22 and 30—Reserved 
These bits are reserved and should be set to 0. Ignores on write and returns a O on read. 


APG—Access Protection Group 


A maximum of 16 protection groups are supported. The default value of instruction TLB miss 
is O. 


G—Guarded Storage Attribute for Entry 
Default value on instruction TLB miss is O. 


0 = Unguarded storage. 
1 = Guarded storage. 


PS—Page Size Level One | 
Default value on instruction TLB miss is 00. 


00 = Small (4K or 16K). 
O1 = 512K. 

11 = 8M. | 

10 = Reserved. 
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V—Entry Valid 
Default value on instruction TLB miss is 1. 


0 
1 


Entry is not valid. 
Entry is valid. 


11.6.1.11 MMU DATA TABLEWALK CONTROL REGISTER. The MMU data tablewalk 
control (MD_TWC) register contains the second level pointer and access protection group 
of an entry to be loaded into the translation lookaside buffer. 


(IMMR & OxFFFF0000) + 0x797 





NOTE: — = Undefined. 


L2TB—Tablewalk Level 2 Base Value 
These bits are the most-significant bits of the level two pointer. 


Bits 20—22—Reserved 


When written, these bits are reserved and should be set to 0. When read, they return 
MD_EPN[10:19] when MD_CTRywam = | and MD_EPN[12:21] when. MD_CTRrwam = 0 





APG—Access Protection Group 


When written, this field supports a maximum of 16 protection groups. It is set to 0000 on the 
data TLB miss. When read, it returns MD_EPN[10:19] when MD_CTRyway = 1 and 
MD_EPN[12:21] when MD_CTR way = 0. 


G—Guarded 


When written, this bit of the entry has the following settings and is set to 0 on a data TLB 
miss: 


O = Unguarded storage. 
1 = Guarded storage. 
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When read, these bit returns MD_EPN[10:19] when MD_CTRyway = 1 and MD_EPN[12:21] 
when MD_CTR wan = 0. 


PS—Page Size 
When written, this field has the following settings and is set to 0 on a data TLB miss. When 
this field is read, it returns a zero. 


00 = Small (4K or 16K). 
O1 = 512K. 

11 = 8M. 

10 = Reserved. 


When read, this field returns MD_EPN[10:19] when MD_CTRyway = 1 and MD_EPN[12:21] 
when MD _CTRrwam = = 0. 


WT—Writethrough 


When written, this bit has the following settings and is set to 1 on a data TLB miss. When 
this bit is read, it returns a zero. 


0 = Copyback data cache policy page entry. 
1 = Writethrough data cache policy page entry. 


V—Valid 
When written, this bit has the following settings and is set to 1 on a data TLB miss. When 
this bit is read, it returns a zero. 


O= Entry is invalid. 
1 = Entry is valid. 
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11.6.1.12 MMU TABLEWALK BASE REGISTER. The MMU tablewalk base (M_TWB 
register contains a pointer to the level one table to be used in hardware-assisted tablewalk 
mode. 


4 3 3 : 
at 
rec s : 
ee ey pe bie Caen Ege oe 


LiTB LIINDX 


(IMMR & OxFFFFO000) + 0x796 





NOTE: — = Undefined. 


L1TB—Tablewalk Level 1 Base Value _ 
These bits are the most-significant bits of the level one pointer. 


L1INDX—Level 1 Table Index 


This field is ignored on write. It returns MD_EPN[0:9] on read when MD_CTRyway = 1 and 
MD_EPN[2:11] when MD_CTRywaw = 0. 


Bits 30-31—Reserved 
These bits are reserved and should be set to 0. Ignores on write and returns a 0 on read. 
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11.6.1.13 MMU TABLEWALK SPECIAL REGISTER. The MMU tablewalk special 
(M_TW) register is temporarily used in the software tablewalk interrupt handlers. 


M_TW 










ee Sees Oe ) Geaeaiacs eae ere 
(IMMR & OxFFFFO000) + 0x799 | | | 
; es ae 






: | (IMMR & OxFFFFOO00) + 0x799 


NOTE: — = Undefined. 


11.6.2 MMU Data Content-Addressable Registers 


The MD_CAM, MD_RAMO, and MD_RAM1 registers are interface registers that allow you 
to read data memory management unit CAM and RAM entries. If you try to write to the 
MD_CAM register using the mtspr instruction, the CAM and RAM values of the entry 
indexed by the DTLB_INDX field to MD_CAM, MD_RAMO, and MD_RAM1 will be loaded. 
The source register in the mtspr instruction can be any register, since its value is not used. 
The values of the MD_CAM, MD_RAMO, and MD_RAM1 registers can be read using the 
mtspr instruction. If you try to write to the MD_RAMO and MD_RAM1 registers using the 
mtspr instruction, it will be considered a NOP (no operation) instruction. 
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11.6.2.1 MMU DATA CAM ENTRY READ REGISTER. When the content-addressable. 
memory of the MMU data CAM entry read (MD_CAM) register is read, it contains the 
effective address and page sizes of an entry indexed by the DTLB_INDxX field of the 
MD_CTR. This register is only updated when you write a value to it. 


MD_CAM 













(IMMR & OxFFFFOO00) + 0x824 


NOTE: — = Undefined. 


EPN—Effective Page Number 
These bits are the most-significant bits of the page’s effective address. 


SPVF—Subpage velalty Flags 


For Bit 20: 
ni Subpage 0 (address[20:21] = 00) | is not valid. 
= Subpage 0 (address[20:21] = 00) is valid. 


For Bit 21: 
O= Subpage 1 (address[20:21] = 01) is not valid. 
= Subpage 1 (address[20:21] = 01) is valid. 


For Bit 22: | 
0 = Subpage 2 (address[20:21] = 10) is not valid. 
= Subpage 2 (address[20:21] = 10) is valid. 


For Bit 23: 


O= Subpage 3 (address[20:21] = 11) is not valid. 
= Subpage 3 (address[20:21] = 11) is valid. 
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PS—Page Size 
000 = 4K. 
001 = 16K. 
011 = 512K. 
111 = 8M. 
010 = Reserved. 
100 = Reserved. 
101 = Reserved. 
110 = Reserved. 


SH—Shared Page 


O = This entry matches only if the ASID field in the data TLB entry matches the value 
of the M_CASID register. 
ASID comparison is disabled for the entry. 


—s 
II 


AS|ID—Address Space ID 


This field is the address space ID of the TLB entry to be compared with the CASID field of 
the M_CASID register. 


11.6.2.2 MMU DATA RAM ENTRY READ REGISTER 0. The MMU data RAM entry read 
register 0 (MD_RAMO) contains the physical page number and page attributes of an entry 
indexed by the DTLB_INDxX field of the MD_CTR. This register is only updated when you 

write a value to it. 


MD_RAMO 


(IMMR & OxFFFF0000) + 0x825 


(IMMR & OxFFFFO000) + 0x825 





NOTE: — = Undefined. 


RPN—Real Page Number 
These bits are the most-significant bits of the page’s physical address. 
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PS—Page Size 
000 = 4K. 
001 = 16K. 
011 = 512K. 
111 = 8M. 


010 = Reserved. 
100 = Reserved. 
101 = Reserved. 
110 = Reserved. 


APGI—Access Protection Group Inverted 


This field is an inversion of the access protection group in the MD_TWC register. 


G—Guarded 


O = Unguarded storage. 
1 = Guarded storage. 


WT—Writethrough 


0 = Copyback data cache policy page entry. 
_ 1= Writethrough data cache policy page entry. 


Cl—Cache-Inhibit 
When this bit is 0, it is not cache inhibited. 


Bits 30-—31—Reserved 
These bits are reserved and should be set to O. 
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11.6.2.3 MMU DATA RAM ENTRY READ REGISTER 1. The MMU data RAM entry read 


register 1 (MD_RAM1) contains the protection mode information of the entry indexed by the 
DTLB_INDX field of the MD_CTR. This register is only updated when you write a value to it. 


MD_RAM1 





RESERVED 


| (IMMR & OxFFFF0000) + 0x826 


} sar | URPo | uwro | URP1 | UwPi | URP2 | UWP2 | URP3 | UWP3 
(IMMR & OxFFFF0000) + 0x826 


NOTE: — = Undefined. 














Bits O-16—Reserved 
These bits are reserved and should be set to 0. 


C—Change Bit for Data Entry TLB 


0 = Unchanged region. Write access to this page results in the implementation-specific 
instruction MMU interrupt invocation. software should take an appropriate action 
before setting this bit to 1. 

1 = Changed region. Write access is allowed to this page. 


EVF—Entry Valid Flag 


O= Entry is invalid. 
1 = Entry is valid. 


~ 

= 

Lu : 
Lu 
S 

4 

= 
<= 
= 
> 

| 
(e) 
Bee 
tt ae 
i) 


SA—Privileged (Supervisor) Access 
For Bit 19: 


O= Subpage 0 (address[20:21]=00) privileged access is not permitted. 
= Subpage 0 (address[20:21]=00) privileged access is permitted. 





For Bit 20: | 
0 = Subpage 1 (address[20:21]=01) privileged access is not permitted. 
1 = Subpage 1 (address[20:21]=01) privileged access is permitted. 
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For Bit 21: 
0= Subpage 2 (address[20:21]=10) privileged access is not permitted. 
1 = Subpage 2 (address/[20:21]=10) privileged access is permitted. 


For Bit 22: 
0 = Subpage 3 (address[20:21]=11) privileged access is not permitted. 
1 = Subpage 3 (address[20:21]=11) privileged access is permitted. 


SAT—Privileged (Supervisor) Access Type 


0 = Privileged access type is read-only. 
1 = Privileged access type is read/write. 


URPO—Problem (User) Read Permission Page 0 


0 = Subpage 0 (address[20:21]=00) problem read access is not permitted. 
1 = Subpage 0 (address[20:21]=00) problem read access is permitted. 


UWPO—Problem (User) Read Permission Page Zero 


0 = Subpage 0 (address[20:21]=00) problem write access is not permitted. 
1 = Subpage 0 (address[20:21]=00) problem write access is permitted. 


URP1—Problem (User) Read Permission Page 1 


O= Subpage 1 (address[20:21|=01) problem read access is not permitted. 
1 = Subpage 1 (address[20:21]=01) problem read access is permitted. 


URP2—Problem (User) Read Permission Page Two 


0 = Subpage 2 (address[20:21]=10) problem read access is not permitted. 
1 = Subpage 2 (address[20:21]=10) problem read access is permitted. 


UWP2—Problem (User) Write Permission Page Two 


0= Subpage 2 (address[20:21]=10) problem write access is not permitted. 
1 = Subpage 2 (address[20:21]=10) problem write access is permitted. 


URP3—Problem (User) Read Permission Page Three 


O= Subpage 3 (address[20:21]=11) problem read access is not permitted. 
1 = Subpage 3 (address[20:21]=11) problem read access is pow 
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UWP3—Probiem (User) Write Permission Page Three 


0 = Subpage 3 (address[20:21]=11) problem write access is not permitted. 
= Subpage 3 (address[20:21]=11) problem write access is permitted. 
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11.6.3 MMU Instruction Content-Addressable Registers 


The MI_CAM, MI_RAMO, and MI_RAM1 registers are interface registers that allow you to 
read data memory management unit CAM and RAM entries. If you try to write to the 
MI_CAM register using the mtspr instruction, the CAM and RAM values of the entry indexed 
by the DTLB_INDX field to MI_CAM, MI_RAMO, and MI_RAM1 will be loaded. The source 
register in the mtspr instruction can be any register, since its value is not used. The values 
of the MI_CAM, MI_RAMO, and MI_RAM1 registers can be read using the mtspr instruction. 
If you try to write to the MI_RAMO and MI_RAM1 registers using the mtspr instruction, it will 
be considered a NOP (no operation) instruction. 


11.6.3.1 MMU INSTRUCTION CAM ENTRY READ REGISTER. When the 
content-addressable memory of the MMU instruction CAM entry read (MI_CAM) register is 
read, it contains the effective address and page sizes of an entry indexed by the ITLB_INDX 
field of the MI_CTR. This register is only updated when you write a value to it. 


MI_CAM 


(IMMR & OxFFFFO000) + 0x816 


ee ee ee Ss 





EPN—Effective Page Number 
These bits are the most-significant bits of the page’s effective address. 


PS—Page Size 
000 = 4K. 
001 = 16K. 
O11 = 512K. 
111 = 8M. 


010 = Reserved. 
100 = Reserved. 
101 = Reserved. 
110 = Reserved. 
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AS|ID—Address Space ID 


This field represents the data TLB entry to be compared with the CASID field in the 
M_CASID register. 


-SH—Shared Page 


0 = This entry matches only if the ASID field in the data TLB entry matches the value 
of the M_CASID register. 
1 = ASID comparison is disabled for the entry. 


SPV—Subpage Validity 
Bit 28: 
0= Subpage 0 (address[20:21]=00) is not valid. 
1 = Subpage 0 (address[20:21]=00) is valid. 


Bit 29: 
O= Subpage 1 (address[20:21]=01) is not valid. 
1 = Subpage 1 (address[20:21]=01) is valid. 


Bit 30: 
0 = Subpage 2 (address[20:21]=10) is not valid. 
1 = Subpage 2 (address[20:21]=10) is valid. 


Bit 31: 
0= Subpage 3 (address[20:21]=11) is not valid. 
1 = Subpage 3 (address[20:21]=11) is valid. 
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11.6.3.2 MMU INSTRUCTION RAM ENTRY READ REGISTER 0. The MMU instruction 
RAM entry read register 0 (MI_RAMO) contains the physical page number and page 
attributes of an entry indexed by the ITLB_INDX field of the MI_CTR. This register is only 
updated when you write to the MI_CAM register. 


MiI_RAMO 





7 (IMMR & OxFFFF0000) + 0x817 


FREESE 


(IMMR & OxFFFF0000) + 0x817 


NOTE: — = Undefined. 


RPN—Real Page Number 
These bits are the most-significant bits of the page’s physical address. 


PS_B—Page Size 


z 
000 = 4K. i 
001 = 16K. © 
011 = 512K. z 
111 = 8M. > 
010 = Reserved. = 
100 = Reserved. = 
101 = Reserved. 


110 = Reserved. 





Cl—Cache-Inhibit 
When this bit is 0, it is not cache-inhibited. 





APG—Access Protection Group 


A maximum of 16 protection groups are supported and are represented in one’s compliment 
format. 
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SFP—Privileged (Supervisor) Fetch Permission 


Bit 28: 
0 = Subpage 0 (address[20:21]=00) privileged fetch is not permitted. 
1 = Subpage 0 (address[20:21]=00) privileged fetch is permitted. 


Bit 29: 
Subpage 1 (address[20:21]=01) privileged fetch is not permitted. 
Subpage 1 (address[20:21]=01) privileged fetch is permitted. 


— © 
Ht fl 


Bit 30: 
O= Subpage 2 (address[20:21]=10) privileged fetch is not permitted. 
1 = Subpage 2 (address[20:21]=10) privileged fetch is permitted. 


B 
O= Subpage 3 (address[20:21]=11) privileged fetch is not permitted. 
1 = Subpage 3 (address[20:21]=11) privileged fetch is permitted. 


11.6.3.3 MMU INSTRUCTION RAM ENTRY READ REGISTER 1. The MMU instruction 
RAM entry read register 1 (MI_RAM1) contains the protection mode information of the entry 
indexed by the ITLB_INDX field of the MI_CTR. This register is only updated when you write 
to the MI_CAM register. 


sor 


ie Ge 


2s wis wnt 4 es ; ” a ese wean ' = ; te 
: E: ss ie ; E # f , 
meer dere Pees 


= 
m 
= 
© 
=e) 
-< 
= 
P 
= 
> 
?) 
m 
= 
m 
= 
a | 





(IMMR & OxFFFFO000) + 0x818 





Bits O-25—Reserved 
These bits are reserved and should be set to zero. 
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UFP—Problem (User) Fetch Permission 
Bit 26: 
O= Subpage 0 (address[20:21]=00) problem fetch is not permitted. 
1 = Subpage 0 (address[20:21]=00) problem fetch is permitted. 


Bit 27: 
0 = Subpage 1 (address[20:21]=01) problem fetch is not permitted. 
1 = Subpage 1 (address[20:21]=01) problem fetch is permitted. 


Bit 28: 
O= Subpage 2 (address[20:21]=10) problem fetch is not permitted. 
1 = Subpage 2 (address[20:21]=10) problem fetch is permitted. 


Bit 29: 
O = Subpage 3 (address[20:21]=11) problem fetch is not permitted. 
= Subpage 3 (address[20:21]=11) problem fetch is permitted. 


PV—Page Validity 
O= Page is invalid. 
1 = Page is valid. 


G—Guarded 


O = Unguarded storage. 
1 = Guarded storage. 


11.7 INTERRUPTS 


11.7.1 Implementation-Specific Instruction TLB Miss 


The implementation-specific instruction TLB miss interrupt occurs when MSRijp =1 and there 
is an attempt to fetch an instruction from a page whose effective page number cannot be 
found in the instruction translation lookaside buffer. The software tablewalk code is 
responsible for loading the translation information of the missed page from the translation 
table that resides in the memory. Refer to Section 11.8.1.1 Translation Reload Examples 
for more information. 


11.7.2 Implementation-Specific Data TLB Miss 


The implementation-specific data TLB miss interrupt occurs when MSRpp =1 and there is 
an attempt to access a page whose effective page number cannot be found in the data 
translation lookaside buffer. The software tablewalk code is responsible for loading the 
translation information of the missed page from the translation table that resides in the 
memory. Refer to Section 11.8.1.1 Translation Reload Examples for more information. 
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11.7.3 Implementation-Specific Instruction TLB Error 
The implementation-specific instruction TLB error interrupt occurs under one of the following 
conditions: 
¢ The effective address cannot be translated. Either the segment or page valid bit of this 
page is cleared in the translation table. 
e The fetch access violates storage protection. 
e The fetch access is to guarded storage and MSRjp =1. 


The cause of an instruction TLB error interrupt can be found in the save/restore register 1 
(SRR1). For bit assignments, refer to Section 7.3.7.3.12 Implementation-Specific 
Instruction TLB Error Interrupt. It is the software’s responsibility to invoke the instruction 
storage interrupt handler. 


11.7.4 Implementation-Specific Data TLB Error 
The implementation-specific data TLB error interrupt occurs under one of the following 
conditions: 


e The effective address of a load, store, icbi, dcbz, dcbst, dcbf, or debi instruction 
cannot be translated. Either the segment or page valid bit of this page is cleared in the 
translation table. 


e The access violates storage protection. 
e An attempt is made to write to a page with a negated change bit. 
The data storage interrupt status register indicates the cause of the data TLB error interrupt. 


For bit assignments refer to Section 7.3.7.3.14 Implementation-Specific Data TLB Error 
Interrupt. It is the software’s responsibility to invoke the data storage interrupt handler. 
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11.8 MANIPULATING THE TRANSLATION LOOKASIDE BUFFER 


11.8.1 Reloading the Translation Lookaside Buffer 


The TLB reload (tablewalk) function is performed in the software with optional hardware 
assistance in the following ways: 


e Automatically stores the missed effective data or instruction address and default 
attributes in the MI_LEPN or MD_EPN registers, respectively. This value is loaded into 
the selected entry on a write to MI_LRPN or MD_RPN for the instruction and data 
translation lookaside buffer. 


Automatically updates the replacement location counter to point to the entry to be 
replaced. This value is placed in the xTLB_INDX field of the MI_LCTR and MD_CTR. 


e Generates a level one pointer when a mfspr Rx, M_TWB is performed by the 
concatenation of the level one table base and level one index. See Figure 11-2 and 
Figure 11-3 for details. 


e Generates a level two pointer when a mfspr Rx, MD_TWC is performed by the 
concatenation of the level two table base and level two index. 


e Performs a write to the TLB entry by loading the tablewalk level two entry value to the 
MI_RPN or MD_RPN register. 


A special register (M_TW) is available for the software tablewalk routine, in addition to 
the PowerPC architecture’s special registers (SPRGO-SPRG3). Using this register 
allows for more efficient interrupt handling. 
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11.8.1.1 TRANSLATION RELOAD EXAMPLES. The following are code examples for 
generating the real page number using a two-level tree page table structure. The first 
example is for a data TLB reload and the second is for an instruction TLB reload. Notice that 
the following assumptions are made: 


e M_TWEB holds the base pointer to the first level table. 
e Both instruction and data address translation is turned off (MSRizp =O and MSRpp =0). 


dtlb_swtw 


itlb_swtw 
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mtspr 
mfspr 
lwz 


mtspr 


mfspr 


lwz 
mtspr 
mfspr 


i 1: 


mtspr 


mfspr 


mtspr 


mfspr 
lwz 

mtspr 
mtspr 


mfspr 


lwz 
mtspr 
mfspr 


rfi 


M_TW, R1 
Rl, M_TWB 
Rij. (RL) 
MD_TWC,R1 
R1, MD_TWC 
R1, (R1) 
MD_RPN, R1 
R1, M_TWw 
M_TW, R1 
R1, SRRO 
MD_EPN, R1 
R1, M_TWB 
Rl, (RL) 
MI_TWC,R1 
MD_TWC,R1 
R1, MD_TWC 
R1, (R1) 
MI_RPN, R1 
R1, M_TW 
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+ + + + FS HS HE HF FSF HSE FH 


+ 6+ + H+ HF OE OE HE UH OCU HECU HC HLCUM HLCUh HhLhUhU HHhUhU HS hUH 


save R1 

load R1 with level one pointer 
Load level one page entry 

save level two base pointer and 
level one attributes 

load R1 with level two pointer 
while taking into account the 
page size 

Load level two page entry 

Write TLB entry 


restore R1 


save R1 

load R1 with instruction miss 
effective address (the same data 
may be taken from the MI_EPN 
register) 

Save instruction miss effective 
address in MD_EPN 

load R1 with level one pointer 
Load level one page entry 

save level one attributes 

save level two base pointer 
load R1 with level two pointer 
while taking into account the 
page size 

Load level two page entry 
Write TLB entry 


restore R1 
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11.8.2 Controlling the TLB Replacement Counter 


The TLB replacement counter can be programmed to only select among the first six entries 
in each translation lookaside buffer by setting the RSV2I bit in the MI_CTR or the RSV2D 
bit in the MD_CTR. These control bits also affect the tlbia instruction. Replacement counters 
are cleared to zero after execution of the tlbia instruction and the counters decrement after 
an appropriate TLB reload. 








11.8.3 Invalidating the Translation Lookaside Buffer 


The MPC823 implements the tlbie instruction to invalidate the TLB entries. This instruction 
invalidates TLB entries in the translation lookaside buffer that hits, including the reserved 
entries. Notice that with 4K page size, the 22 most-significant bits of the effective address 
are used in the comparison because no segment registers are implemented. Although, for 
entries with larger page sizes than 4K, some of the lower bits of the effective page number 
are ignored. The ASID value in the entry is ignored for the purpose of matching an 
invalidated address, thus multiple entries can be invalidated if they have the same etective 
address and different ASID values. 


The MPC823 supports the tlbia instruction to invalidate all entries in both translation 
lookaside buffers. If the RSV2D or RSV2I bit is set for a translation lookaside buffer, the two 
reserved entries will not be invalidated when tlbia is executed. However, the software can 
explicitly invalidate one or more of these entries by setting the x TLB_INDxX field in the 
MD_CTR or MI_CTR, which negates the EV bit in the MD_EPN or MI_EPN register and 
performs a write to the appropriate MD_RPN or MI_RPN register. The translation lookaside 
buffers are not automatically invalidated on reset, but they are disabled. However, they must 
be invalidated under program control. 


11.8.4 Loading the Reserved TLB Entries 


To load a single reserved entry in the translation lookaside buffer, follow these steps: 








1. Disable the translation lookaside buffer by clearing MSRip or MSRpr as needed. 
2. Clear the RSV2x bit in the Mx_CTR. 


3. Invalidate the effective address of the reserved page by using the tibia or tlbie 
instruction. 


4. Set the xTLB_INDxX fields of the Mx_CTR to the appropriate value (6 or 7). 


5. Load the Mx_EPN register with the effective page number, the ASID with the reserved 
page, and set the EV bit to 1. 


_ 6. Run software tablewalk code to load the appropriate entry into the translation 
lookaside buffer. Refer to Section 11.8.1.1 Translation Reload Examples for 
examples of this code. 


7. If needed, repeat the three previous steps to load other TLB entries. 
8. Set the RSV2x bit in the Mx_CTR. 
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11.9 REQUIREMENTS FOR ACCESSING THE MEMORY MANAGEMENT 
UNIT CONTROL REGISTERS 


All instruction and data memory management unit control registers should be accessed. 

- when instruction and data address translation is turned off. Prior to an mtspr MD_DBCAM 
Rx instruction, an eieio instruction should be placed and executed before you write to the 
Mx_CAM register. 


c= 
=m 
i 
O 
=e) 
< 
— a 
> 
= 
> 
G) 
mi 
= 
Ti . 
—j 





11-52 MPC823 USER’S MANUAL MOTOROLA 


SECTION 12 
SYSTEM INTERFACE UNIT 


The system interface unit controls system startup, initialization and operation, protection, as 
well as the external system bus. The system configuration and protection function controls 
the overall system and provides various monitors and timers, including the bus monitor, 
software watchdog timer, periodic interrupt timer, PowerPC™ decrementer, timebase, and 
real-time clock. The clock synthesizer generates the clock signals for other modules and 
external devices that the system interface unit uses. This circuitry generates the system 
clock from an inexpensive 32kHz crystal or an oscillator with a maximum frequency of 
5MHz. The system interface unit supports various low-power modes that supply different 
ranges of power consumption, functionality, and wake-up time. The clock scheme supports 
low-power modes for applications that use baud rate generators and/or serial ports in 
standby mode. The main system clock can be changed dynamically, but the baud rate 
generators and serial ports work with a fixed frequency. For more information on clocks, 
refer to Section 5 Clocks and Power Control. 7 


The external bus interface handles the transfer of information between internal buses and 
the memory or peripherals in the external address space. The MPC823 is designed to allow 
external bus masters to request and obtain mastership of the system bus. For additional 
information on bus operation, see Section 13 External Bus Interface. The memory 
controller module provides a glueless interface to many types of memory devices and 
peripherals and it supports a maximum of eight memory banks, each with their own device 
and timing attributes. Memory control services are provided to both internal and external 
masters. The MPC823 supports circuitboard test strategies through a user-accessible test 


logic that is fully compliant with information in Section 21 IEEE 1149.1 Test Access Port. 


Note: The MPC823’s external address bus is 26 bits wide, while the internal address 
bus is 32 bits wide. Therefore, external accesses are considered internally as 
26-bit accesses (A[6:31]) with A[0:5] equal to 0, while internal accesses are full 
32-bit accesses. 





The PCMCIA host adapter module provides all control logic for a PCMCIA interface. A host 
adapter interface fully compliant with the PCMCIA Standard, Release 2.1+ (PC Card -16)). 
It can support one PCMCIA socket with a maximum of eight memory or I/O windows. 


<= Note: Both the MPC823 and MPC821 have the same PCMCIA module except that the 
MPC823 has only one valid slot (Slot B). Programming a window to be assigned 
to Slot A may cause an erroneous operation. 
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System Interface Unit 
12.1 FEATURES 
The following is a list of the system interface unit’s main features: 


e System Configuration and Protection 
e System Interrupt Configuration 
e System Reset Monitoring and Generation 


Clock Synthesizer 

¢ Power Management 

e Real-Time Clock 

¢ PowerPC Decrementer 
© Timebase 

Periodic Interrupt Timer 


QD 


¢ External Bus Interface Control 

° Eight Memory Banks Supported aye the Memory Controller 

e Debug Support | 

¢ PCMCIA Host Adapter Module Supports Eight Memory or I/O Windows 
IEEE 1149.1 Test Access Port 


12.2 SYSTEM CONFIGURATION AND PROTECTION 


The MPC823 incorporates many system functions that normally must be provided in 
external circuits. It is designed to provide maximum system safeguards against hardware 
and/or software faults. The following features are provided j in the system configuration and 
protection submodule: 
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e Interrupt Contiguration—Atlows you to configure the system according to your own 
requirements. The functions include control of parity checking, show cycle operation, 
and part and mask number constants. 


Bus Monitor—Monitors the TA response time for all bus accesses initiated by the 

internal masters. A TEA signal is asserted if the TA response limit is exceeded. The bus 

monitor measures time between TS and any termination of the bus cycle, including TA, 
_ TEA, and RETRY. 


Software Watchdog Timer—Asserts a reset or nonmaskable interrupt that is selected 
by the system protection control register (SYPCR) if the software fails to service the 
software watchdog timer after a certain period of time. After system reset, the software 
watchdog timer, if enabled, selects a maximum timeout period and asserts a system 
reset if the timeout is reached. The software watchdog timer can be disabled or its 
timeout period can be changed in the SYPCR. Once the SYPCR is written, it cannot be 
written again until a system reset. 
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e Periodic Interrupt Timer—Generates periodic interrupts to be used with the real-time 
operating system or the application software. The periodic interrupt timer is clocked by 
the PITRTCLK clock, thus providing a period from 122 microseconds to 8,000 
milliseconds assuming a 32.768kHz crystal. The periodic interrupt timer function can be 
disabled if it is not needed. 


¢ PowerPC Timebase Counter—Provides a timebase reference for the operating 
system or application software. This 64-bit timebase counter is defined by the PowerPC 
architecture and has two independent reference registers that generate a maskable 
interrupt when the programmed value in one of the registers is reached. The associated 
bit in the timebase status register is set for the reference register that generated the 
interrupt. The timebase is clocked by the TMBCLK clock. 


e PowerPC Decrementer—Provides a decrementer interrupt and is clocked at the same 
frequency as the timebase. This 32-bit decrementing counter is defined by the 
PowerPC architecture to be clocked by the TMBCLK clock. When it is driven by a 4MHz 
oscillator the period for the decrementer is 4,295 seconds, which is approximately 71.6 
minutes. 


e Real-Time Clock—Provides a time-of-day information to the operating system or 
application software. It is composed of a 45-bit counter and an alarm register. A 
maskable interrupt is generated when the counter reaches the value programmed in the 
alarm (RTCAL) register. The real-time clock is clocked by the PITRTCLK clock. 


e Freeze Support—TIhe system interface unit determines whether the software 
watchdog timer, periodic interrupt timer, timebase, decrementer, and real-time clock 
should continue to run in freeze mode. 
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Figure 12-1 illustrates a block diagram of the system configuration and protection logic. 
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Figure 12-1. System Configuration and Protection Logic 
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12.3 INTERRUPT CONFIGURATION 


Many aspects of MPC823 system configuration are controlled by the SIU module 
configuration register (SIUMCR). The SIUMCR primarily controls the external bus arbitration 
logic, external master support, and pin multiplexing. See Section 12.12.1.1 SIU Module 
Configuration Register for more information. 


12.3.1 The Interrupt Structure 


The system interface unit receives interrupts from internal sources, such as the periodic 
interrupt timer, real-time clock, communication processor module (CPM), and the external 
IRQx pins. The MPC823 interrupt structure is illustrated in Figure 12-2. 
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Figure 12-2. MPC823 Interrupt Structure 
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System Interface Unit 


If it is programmed to generate an interrupt, the software watchdog timer always generates 
a nonmaskable interrupt (NMI) to the core. The external IRQO pin can generate a 
nonmaskable interrupt as well. Notice that the core takes the system reset interrupt when a 
nonmaskable interrupt is asserted and the external interrupt when any other interrupt is 
asserted by the interrupt controller. Each one of the external IRQ pins has its own dedicated 
assigned priority level and there are eight additional interrupt priority levels. Each one of the 
system interface unit internal interrupt sources (the interrupt request that is generated by the 
communication processor module’s interrupt controller) can be assigned by the software to 
any one of those eight interrupt priority levels. Thus, a very flexible interrupt scheme is 
realized. — 





12.3.2 Priority of the Interrupt Sources 


The system interface unit has 15 interrupt sources that assert just one interrupt request to 
the core. There are seven external IRQ pins and eight interrupt levels. The priority between 
all interrupt sources is shown in Table 12-1. 


Table 12-1. Priority of System Interface Unit Interrupt Sources 


PRIORITY INTERRUPT SOURCE INTERRUPT CODE 
LEVEL DESCRIPTION 
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12.3.3 Programming the Interrupt Controller 


The system interface unit’s interrupt controller consists of the SIPEND, SIMASK, SIEL, and 
SIVEC registers. 


12.3.3.1 SIU INTERRUPT PENDING REGISTER. The 32-bit SIU interrupt pending 
(SIPEND) register contains bits that individually correspond to an interrupt request. If they 
are set, the bits associated with internal exceptions indicate that an interrupt service is 
requested, if they are not masked by the corresponding bit in the SIMASK register. These 
bits reflect the status of the internal requesting device and they are cleared when the 
appropriate actions are software-initiated in the device itself. The bits associated with the 
IRQx pins have a different behavior depending on the sensitivity defined for them in the SIEL 
register. When an IRQx pin is defined as a “level” interrupt the corresponding bit behaves 
similar to the bits associated with internal interrupt sources. When an IRQx pin is defined as 

n “edge” interrupt and if the corresponding bit is set, it indicates that a falling edge was 
detected on the line. These bits are reset by writing a 1 to them. 











SIPEND 


R00] tor fins |e] one Ros | a] | wes] ots] | Ls | aT] WT 
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(IMMR & OxFFFFO000) + 0x010 





IRQ—Interrupt Request 0-7 
When set, this field indicates an edge-triggered interrupt of corresponding value. 


QO = The appropriate interrupt is not pending. 
1 = The appropriate interrupt is pending. 


LVL—Level 0-7 
When set, this field indicates a pending level interrupt of corresponding value. 


O= The appropriate interrupt is not pending. 
1 = The appropriate interrupt is pending. 


Bits 16—31—Reserved 
These bits are reserved and should be set to 0. 
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System Interface Unit 





12.3.3.2 SIU INTERRUPT MASK REGISTER. The 32-bit read/write SIU interrupt mask 
SIMASKk) register contains bits that individually correspond to the interrupt request bit in the 
SIPEND register. When a bit is set, it enables the generation of an interrupt request to the 
core. SIMASK is updated by the software and cleared at reset. It is the responsibility of the 
software to determine which of the interrupt sources are enabled at a given time. 


SIMASK 
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IRM—Interrupt Request Mask 0-7 


When set, this field enables an IRQx interrupt request to be generated. The SIPEND register 
contains the IRQ bit. This bit does not mask the interrupt that goes to the CPU. 


0 = Disable the generation of an IRQ bit in the SIPEND register. 
1= Enable the generation of an IRQ bit in the SIPEND register. 


LVM—Level Mask 0—7 
When set, this field enables an interrupt request to be generated. 


0 = Disable the generation of an IRQ bit in the SIPEND register. 
1= Enable the generation of an IRQ bit in the SIPEND register. 


Bits 16—31—Reserved 
These bits are reserved and should be set to 0. 
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12.3.3.3 SIU INTERRUPT EDGE/LEVEL REGISTER. The 32-bit read/write SIU interrupt 
edge/level (SIEL) register contains pairs of bits that correspond to an external interrupt 
request. If set, the EDx bit specifies when a falling edge in the corresponding IRQx signal is 
an interrupt request. When the EDx bit is 0, a low logical level in the IRQx signal is an 
interrupt request. The WMx bit, if set, indicates that a low level detection in the 
corresponding interrupt request line causes the MPC823 to exit low-power mode. 


Bs 


ws 4 [ i] 0s | is] os | ns] D7 | wn 
fofofofolelefofelofolo 
a [a [a [a [ae [ow [we [me [a [ae [a [| | 


RESERVED 


(IMMR & OxFFFFO000) + 0x018 





ED—Edge Detect 0-7 


O= The bits specify that a low logical level in the IRQx signal is detected as an interrupt 
request. 

1 = The bits specify that a falling edge in the corresponding IRQx signal is detected as 
an interrupt request. 





WM—Wake-Up Mask 0-7 


0 = Not allowed to exit from low-power mode. 
1 = Allows low-level detection in the corresponding IRQx signal to exit or wake up the 
MPC823 from low-power mode. 





Bits 16—31—Reserved 
These bits are reserved and should be set to 0. 
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12.3.3.4 SIU INTERRUPT VECTOR REGISTER. The 32-bit read-only SIU interrupt vector 
(SIVEC) register contains an 8-bit code that represents the unmasked interrupt source of 
the highest priority level. The SIVEC register can be read as either a byte, half, or word. 
When read as a byte, a branch table can be used in which each entry contains one 
instruction (branch). When read as a half-word, each entry can contain a full routine of 256 
instructions (max). The interrupt code is equal to the interrupt number multiplied by four, 
which allows indexing into the table. Refer to Figure 12-3 and Table 12-1 for details. 


SIVEC 










RG RESERVED 
3 (IMMR & OxFFFFO000) +0x01C 
T 





RESERVED 
(IMMR & OxFFFFO000) + 0x01E 


INTC—Interrupt Code 
This field indicates the highest priority pending interrupt. 






Bits 8-31—Reserved 


These bits are reserved and should be set to 0. The value equals the interrupt number 
multiplied by four. See Table 12-1 for details. 
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INTR: *ee INTR: ¢*¢ 


Save state Save state 
R3 <- @ SIVEC R3 <- @ SIVEC 
R4 <-- Base of branch table R4 <-- Base of branch table 


bz ~—~RX, R3 0) # load as byte Ihz RX,R3 (0) # load as byte 
add__s*iRX, RX, R4 add RX, RX, R4 

mtspr CTR, RX mtspr CTR, RX 

betr betr 


b  Routinet BASE 1st Instruction of Routine1 
b Routine2 BASE + 400| ist Instruction of Routine2 


b  Routine3 BASE +800! ist Instruction of Routine3 
b Routine4 BASE +C00| 1st Instruction of Routine4 


BASE +1000 


BASE +n 





Figure 12-3. Interrupt Table Handling Example 


12.4 THE BUS MONITOR 


The bus monitor ensures that each bus cycle is terminated within a reasonable period of 
time. The MPC823 system interface unit provides a bus monitor option that monitors 
internally generated external bus accesses on the external bus. At the start of the transfer 
start (TS) signal, the monitor begins counting and stops when the transfer acknowledge (TA) 
or transfer error (TEA) signal is asserted. Within the bus cycle, the burst cycle performs. 
three functions—stops the previous count, resets, and restarts a new count until the next 
transfer acknowledge. The last transfer acknowledge of the burst cycle only stops the 
counter. When a RETRY signal is asserted, it has the same effect as the TA or TEA signal. 
If the monitor times out, a TEA signal is internally asserted by the bus monitor to terminate 
the cycle. The programmability of the timeout allows for a variation in system peripheral 
response time. The timing mechanism is clocked by the system clock divided by eight. The 
maximum value can be 2,040 system clocks. The bus monitor will always be active when 
the FRZ signal is asserted or when a debug mode request is pending, regardless of the state 
of the BMT bit. 





Note: lf the bus monitor is disabled, the. transfer error conditions will not assert the 
TEA pin. 


a 
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12.5 THE POWERPC DECREMENTER 


The 32-bit decrementing counter is defined by the PowerPC architecture to provide a 
decrementer interrupt. This binary counter is clocked by the same frequency as the 
timebase. In the MPC823, the decrementer is clocked by the TMBCLK clock, so you must 
enable the TBE bit in the TBSCR for the decrementer to start. | 


932 
Ty eee 
Gee Fimbclk 


The state of the decrementer is not affected by HRESET and SRESET and, therefore, 
should be initialized by the software. The decrementer runs continuously after power-up. It 
continues counting while HRESET and SRESET are asserted and it is implemented with the 
following requirements.in mind. The decrementer interrupt is also sent to the power-down 
wake-up logic, which allows the CPU to be awaken from power-down mode. 


e The operation of the timebase and decrementer are coherent, which means the 
counters are driven by the same fundamental timebase. 


e The decrementer is unaffected when read. 


e When storing to the decrementer, the value in the decrementer is replaced with the 
value in the GPR. | 


e When Bit 0 (MSB) of the decrementer changes from 0 to 1, an interrupt request is 
signaled. If multiple decrementer interrupt requests are received before the first one is 
reported, only one interrupt is reported. 


¢ If the decrementer is altered by the software and the content of Bit 0 is changed from 
0 to 1, an interrupt request is signaled. | 


A decrementer exception causes a pending decrementer interrupt request in the core. When 
the decrementer interrupt is taken, the request is automatically cleared. The following chart 
shows some of the periods available for the decrementer, assuming that a 4MHz oscillator 
is used. Pe are | 


; 
ee 

| 
ee 
ee 






999999999 ~ 1000. seconds’ 
FFFFFFFF(hex) 4295 seconds sy 
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12.5.1 Decrementer Register 


The 32-bit decrementer (DEC) register is a special-purpose register defined by PowerPC 
architecture. The decrementer causes an interrupt whenever Bit 0 changes from a logic 0 to 
a logic 1. The contents of this register can be read or written to by the mfspr or mtspr 
instruction. This register is undefined at reset. The decrementer is powered by standby 
power and continues counting when standby power is applied. To enable the decrementer 
control bits, use the timebase control and status register. The decrementer and timebase 
share the same TMBCLK. 


DEC 


= 
a 
pa 
. Wl 
oO. 
=z. 
LL 
o 
te 
= 
= 
= 
Lu 
= 
an 
a 
w 


ry 








NOTE: = Undefined. 


DEC—Decrementer 


This field is used by a down counter to cause decrementer interrupts. A read of this register 
always returns the current count value from the down counter. | 
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12.6 THE POWERPC TIMEBASE 
The timebase is defined by the PowerPC architecture and is a 64-bit free-running binary 


counter that is incremented at a frequency determined by each implementation of the 


timebase. There is no interrupt or other indication generated when the count rolls over. The 
period of the timebase depends on the driving frequency. For the MPC823, the timebase is 


clocked by the TMBCLK clock and the period for the timebase is: 


764 





T = 
TE Eimbelk 


The state of the timebase is unaffected by any resets and should be initialized by the 
software. Reads and writes of the timebase are restricted to special instructions. For the 
MPC823 implementation, it is not possible to read or write the entire timebase in a single 
instruction. Therefore, the mttb and mftb instructions are used to move the lower half of the 
timebase while the mttbu and mftbu instructions are used to move the upper half of the 
timebase. The timebase has two reference registers associated with it. A maskable interrupt 
is generated when the timebase count reaches the value programmed in one of the two 
reference registers and the two status bits indicate which of the two reference registers 
generated the interrupt. 


12.6.1 Timebase Register 


The special-purpose 64-bit timebase (TB) register contains a 64-bit integer that is 
periodically incremented. There is no automatic initialization of this register. The system 


- software must perform the initialization. The contents of the register can be written by the 


mtspr instruction and read by the mftb or mftbu instruction. 


TBU 


269 (READ), 285 (WRITE) 


269 (READ), 285 (WRITE) 





NOTE: — = Undefined. 


TBU—Timebase Upper 
The value stored in this field is used as an upper part of the timebase counter. 
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TBL 


268 (READ), 284 (WRITE) 





NOTE: — = Undefined. 


TBL—Timebase Lower 
The value stored in this field is used as the lower part of the timebase register. 
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12.6.2 Timebase Reference Registers 


There are two special-purpose 32-bit read/write timebase reference registers—TBREFU 
and TBREFL—associated with the upper and lower parts of the timebase. When there is a 
match between the contents of the timebase and the reference register, a reference interrupt 
is enabled in the timebase control and status register. 





TBREFU 





TBREFU—Timebase Reference Upper 
These bits represent the 32-bit reference value for the upper part of the timebase. 
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NOTE: — = Undefined. 


TBREFL—Timebase Reference Lower 
These bits represent the 32-bit reference value for the lower part of the timebase. 


12.6.3 Timebase Status and Control Register 


The 16-bit read/write timebase status and control register (TBSCR) controls the timebase 
count enable and interrupt generation. It is also is used for reporting the source of the 
interrupts and can be read at any time. A status bit is cleared by writing a 1 (writing a zero 
has no effect) and more than one bit can be cleared at a time. 
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TBIRQ—Timebase Interrupt Request 


This field determines the interrupt priority level of the timebase. To specify a certain level, 
the appropriate bit should be set. 


REFA and REFB—Reference Interrupt Status 


If set, these bits indicate that a match has been detected between the corresponding ° 
reference register (TBREFU for REFA and TBREFL for REFB) and the timebase low 
register. The bit should be cleared by writing a 1. 
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Bits 10—11—Reserved 
These bits are reserved and should be set to 0. 


- REFAE and REFBE—Reference Interrupt Enable 


If one of these bits is asserted, the timebase generates an interrupt on assertion of the REFA 
or REFB bit. Otherwise, the interrupt is disabled. 


TBF—Timebase Freeze Enable 


0 = The timebase and decrementer are unaffected. 
1 = The FRZ signal stops the timebase and decrementer. 


TBE—Timebase Enable 


0 = Disables timebase and decrementer operation. 
1 = Enables timebase and decrementer operation. 


12.7 THE REAL-TIME CLOCK 


The real-time clock is a 45-bit counter that is clocked by the PITRTCLK clock. It is used to 
provide time-of-day indication to the operating system and application software. The counter 
is not affected by reset and operates in all low-power modes. It is initialized by the software. 
The real-time clock can be programmed to generate a maskable interrupt when the time 
value matches the value programmed in the associated alarm register. It can also be 
programmed to generate an interrupt once every second. A control and status register is 
used to enable or disable the different functions and report the interrupt source. The 
real-time clock registers—RTCSC, RTC, RTSEC, and RTCAL—are protected (“locked”) 
from accidental writes after PORESET. To unlock the registers, you must write a key word 
(55CCAA33) to the RTSCK register. Refer to Section 5.4.2 Keep-Alive Power for more 
information. 
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32-BIT REGISTER 


Figure 12-4. Real-Time Clock Block Diagram 
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12.7.1 Real-Time Clock Status and Control Register 


The real-time clock status and control (RTCSC) register is used to enable the different 
real-time clock functions and for reporting the source of the interrupts. A status bit is cleared 
by writing a 1 (writing a zero has no effect) and more than one status bit can be cleared at 
a time. This register can be read at any time. 


RTCSC 


Ec 


a Pa CS 
pe | | a | 


(IMMR & OxFFFFO000) + 0x220 





NOTE: — = Undefined. 





RTCIRQ—Real-Time Clock Interrupt Request 
This field controls the real-time clock’s interrupt priority level. 


SEC—Once Per Second Interrupt . 
This status bit is set every second and should be cleared by the software. 


ALR—Alarm Interrupt 


This status bit is set when the value a the real-time clock is equal to the value programmed 
in the RTCAL register. 


Bit 10—Reserved 
This bit is reserved and should be set to 0. 


38K—Real-Time Clock Source Select 
The software must set this bit to get the proper timing of a second. 


O= Assumes that it is driven by a 32.768kHz crystal 
1 = Assumes that it is driven by a 38.4kHz crystal. 


SIE—Seconds Interrupt Enable | 
This bit allows the real-time clock to generate an interrupt when the SEC bit is set. 


0 = Disables seconds interrupt. 
= The real-time clock generates an interrupt. 
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ALE—Alarm Interrupt Enable 
This bit allows the real-time clock to generate an interrupt when the ALR bit is set. 


0 = Disables the seconds interrupt. 
1 = The real-time clock generates an interrupt. 


RTF—Real-Time Clock Freeze Enable 


O= The real-time clock is unaffected by the FRZ signal. 
1 = The FRZ signal stops the real-time clock. 


RTE—Real-Time Clock Enable 


O= The real-time clock timers are disabled. 
1= The real-time clock timers are enabled. 


12.7.2 Real-Time Clock Register 


The 32-bit real-time clock (RTC) register contains the current value of the real-time clock. 
The maximum value is approximately 136 years. 


RTC 
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NOTE: — = Undefined. 


RTC—Real-Time Clock 
This field represents time measured in seconds. Each unit represents one second. 
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12.7.3 Real-Time Clock Alarm Seconds Register 


The 32-bit real-time clock alarm seconds (RTSEC) register contains the value to be 
compared with the RTC register and will generate an alarm condition if they match. The 
maximum value is approximately 136 years. 


RTSEC 
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ASEC—Alarm Seconds 
This field contains the value to be compared with the value in the RTC register. 


ty 
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12.7.4 Real-Time Clock Alarm Register 


The 32-bit read/write real-time clock alarm (RTCAL) register is an alarm reference register. 
When the RTC register increments to the value stored in this register, an alarm interrupt is 
generated. 
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ALARM—Alarm Reference Counter 


This field indicates that an alarm interrupt will be generated as soon as there is a match 
between this field and the corresponding bits in the RTC register. The alarm has a 1 second 
resolution. 
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12.8 THE PERIODIC INTERRUPT TIMER 
The periodic interrupt timer consists of a 16-bit counter clocked by a PITRTCLK clock 


supplied by the clock module. It decrements to zero when loaded with a value from the 


periodic interrupt timer count register (PITC) and after the timer reaches zero, the PS bit is 
set and an interrupt is generated if the PIE bit is a logic 1. At the next input clock edge, the 
value in the PITC register is loaded into the counter and the process starts all over again. 

When a new value is loaded into the PITC register, the periodic interrupt timer is updated, 


_ the divider is reset, and the counter starts counting. If the PS bit is not cleared, it generates 


an interrupt at the interrupt controller and the interrupt remains pending until it is cleared. If 
the PS bit is set again, prior to being cleared, the interrupt remains pending until the PS bit 
is cleared. Any write to the PITC register stops the current countdown and the count 
resumes with a new value in the PITC. If the PTE bit is not set, the periodic interrupt timer 
is unable to count and retains the old count value. Reads of the periodic interrupt timer have 
no effect on it. | | | | | 






16-BIT 
MODULUS 
COUNTER 


CLOCK 
DISABLE 


PITRTCLK . 
CLOCK 


3 PIT 
INTERRUPT 


Figure 12-5. Periodic Interrupt Timer Block Diagram 


The timeout period is calculated as: 





pr. PITG+1_ _PITC +1 
period F itetetk (eee a4 
10r128 


Solving this equation using a 32.768kHz external clock gives: 


PITC +1 
8192 





PlTperiod = 


This gives a range from 122 microseconds with a PITC of Ox0000 to a maximum of 8 
seconds with a PITC of OxFFFF. 
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12.8.1 Periodic Interrupt Status and Control Register 


The read/write periodic interrupt status and control register (PISCR) contains the interrupt 
request level and the interrupt status bits. It also controls the 16 bits to be loaded ina 
modulus counter. 


PISCR 


CIEIEE 


ar ae 


(IMMR & OxFFFFO000) + 0x240 





PIRQ—Periodic Interrupt Request Level 


This field allows you to configure any interrupt level for periodic interrupts. See Figure 12-2 
for interrupt request levels. 


PS—Periodic Interrupt Status 
This bit can be negated by writing a 1 to it (zero has no effect). 


O= The periodic interrupt timer is unaffected. 
1 = The periodic interrupt timer has issued an interrupt. 


Bits 9-12—Reserved 
These bits are reserved and should be set to 0. 


PlE—Periodic Interrupt Enable 


O= Disables the PS bit. 
1 = Enables the PS bit to generate an interrupt. 


PITF—Periodic Interrupt Timer Freeze Enable 


O= The periodic interrupt timer is unaffected by the FRZ signal. 
1 = The FRZ signal stops the periodic interrupt timer. 


PTE—Periodic Timer Enable 


O= The periodic interrupt timer is disabled. 
1 = The periodic interrupt timer is enabled. 
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12.8.2 Periodic Interrupt Timer Count Register 


The read/write periodic interrupt timer count (PITC) register contains a 16-bit value that wi 
be loaded into the periodic interrupt down counter. , 


PITC , 


Rs 


Rage : 
See fs eS 3 


RESERVED 


IMMR & OxFFFFO000) + 0x246 





NOTE: — = Undefined. 


P!ITC—Periodic Interrupt Timer Count 


This field contains the count for the periodic timer. If this field is loaded with the value 
OxFFFF, the maximum count period will be selected. 


Bits 16-31—Reserved 
These bits are reserved and should be set to 0. 


12-24 MPC823 USER’S MANUAL MOTOROLA 


System Interface Unit 


12.8.3 Periodic Interrupt Timer Register 


The periodic interrupt timer register (PITR) is a read-only register that shows the current 
value in the periodic interrupt down counter. Writes to this register do not affect this register 
and reads of this register do not have any affect on the counter. 


PITR 


TT eee en ag re 










oe Gs ‘g Bee : 
(IMMR & OxFFFFO000) + 0x248 


RESERVED 
(IMMR & OxFFFFO000) + 0x24A | 


NOTE: — = Undefined. 









PlT—Periodic Interrupt Timing Count 


This field contains the current count remaining for the periodic timer. Writes have no effect 
on this field. 


Bits 16-31—Reserved 
These bits are reserved and should be set to 0. 
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12.9 THE SOFTWARE WATCHDOG TIMER 


The system interface unit provides the software watchdog timer (SWT) option that prevents 
system lockout when the software gets trapped in loops without a controlled exit. The 
software watchdog timer is enabled after system reset to automatically generate a system 
reset if it times out. If you do not need the software watchdog timer, you must clear the SWE 
bit in the system protection control register (SYPCR) to disable it. If it is used, the software 
watchdog timer requires a special service sequence to be executed on a periodic basis. If 
this periodic servicing action does not occur, the software watchdog timer times out and 
issues a reset or a nonmaskable interrupt, which is programmed in the SWRI bit of the 
SYPCR. Once the SYPCR register is written by the software, the state of the SWE bit cannot 
be changed. Refer to the system configuration and protection registers for more information. 
To service the software watchdog timer, write Ox556C and 0xAA339 to the software service 
register. 


_ This sequence clears the watchdog timer and the timing process begins again. If any value 


other than 0x556C or OxAA339 is written to the software service register (SWSR), the entire 
sequence must start over. Although the writes must occur in the correct order before a 
timeout occurs, any number of instructions may be executed between the writes. This allows 
interrupts and exceptions to occur between the two writes when necessary. Refer to 
Figure 12-6 for more information. 7 


RESET 0X556C / DON'T_RELOAD ~ 


- 








STATE 1 
AITING FOR OXAA3§ 


OXAA39 / RELOAD 






NOT 0X556C / DON'T_RELOAQ 
NOT OXAA39 / DON’T_RELOA® 


Figure 12-6. Software Watchdog Timer Service State Diagram 


Although most software disciplines permit or encourage the watchdog concept, some 
systems require a selection of timeout periods. For this reason, the software watchdog timer 
must provide a selectable range for the timeout period. Figure 12-7 illustrates the present 
method for handling this requirement. Figure 12-7 also shows the range that the value in the 
SWTC field determines. This value is then loaded into a 16-bit decrementer clocked by the 
system clock. When necessary, an additional divide by 2,048 prescaler is used. 
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The decrementer begins counting when it is loaded with a value from the SWTC field. After 
the timer reaches OxO, a software watchdog expiration request is issued to the reset or NMI 
control logic. At reset, the value in the SWTC register is set to the maximum value and is 
loaded into the software watchdog register (SWR) again, thus starting the process over. 
When a new value is loaded into the SWTC register, the software watchdog timer will not be 
updated until the servicing sequence is written to the SWSR register. If the SWE bit is loaded 
with the value 0, the modulus counter will not count. 









SERVICE 
LOGIC 














CORE _ 1 CLOCK >| DIVIDE BY} —y 
CLOCK * | DISABLE 2,048 RELOAD 
MUX 16-BIT RESET 
SWR/DECREMENTER} ORNMI 
1 ROLLOVER = 0 
FRZ 
TIMEOUT 


SWP 


Figure 12-7. Software Watchdog Timer Block Diagram 


12.9.1 Software Service Register 


The software service register (SWSR) is the location that the software watchdog timer 
servicing sequence writes to. To prevent a SWT timeout, a write of Ox556C followed by 
OxAA39 should be written to this register. The SWSR can be written at any time, but returns 
all zeros when read. 


SWSR 


W 


: (IMMR & OxFFFFO000) + 0x00E 


SEQ—Sequence 
This field is the pattern that is used to control the state of the software watchdog timer. 
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12.10 FREEZE OPERATION 


When the FRZ signal is asserted, the clocks to the software watchdog, periodic interrupt 
timer, real-time clock, timebase counter, and decrementer can be disabled. This is 
controlled by the associated bits in the control register of each timer. If they are programmed 
to stop counting when FRZ is asserted, the counters maintain their values until FRZ is 
negated. The bus monitor, however, will be enabled regardless of this signal's state. 


12.10.1 Low-Power Stop Operation 


When the PowerPC core is set in a low-power mode (doze, sleep, deep sleep), the software 
watchdog timer is frozen. It remains frozen and maintains its count value until the core exits 
this mode and continues to execute instructions. The periodic interrupt timer, decrementer, 
and timebase are not influenced by these low-power modes and they continue to run at their 
respective frequencies. These timers can generate an interrupt to bring the MPC823 out of 
the low-power modes. 
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12.11 MULTIPLEXING THE SYSTEM INTERFACE UNIT PINS 


Due to the limited number of pins available in the MPC823 package, some of the 
functionalities share pins. The actual MPC823 pinout is illustrated in 

Section 2 External Signals. The following table shows how the functionality is controlled 
on each pin. 


Table 12-2. Multiplexing Control 


TSIZO/REG Dynamically active depending if the transaction addresses a slave controlled by 
the PCMCIA interface. 


BDIP/GPL_B5 Programmed in the SIUMCR. 
RSV/IRQ2 
KR/RETRY/IRQ4/SPKROUT 
DP[0:3)/IRQ[3:6] 

FRZ/IRQ6 


CS6/CE1_B 
CS7/CE2_B 


































Address matching and bank valid bits. 


When there is a transfer such that there is a match in either memory controller 
pak? any PCMCIA bank mapped to slot B, the CS(6)/CE(1)_B will be 
asserte 

When there is a transfer such that there is a match in either memory controller |. 
een 4 any PCMCIA bank mapped to slot B, the CS(7)/CE(2)_B willbe | 
asserte 
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WE0/BS_ABO/IORD 
WE1/BS_AB1/IOWR 
WE2/BS_AB2/PCOE 
WE3/BS_AB3/PCWE 


GPL_A0/GPL_BO Dynamically active depending on the machine (UPMA or UPMB) assigned to 
control the required slave. 


OE/GPL_A1/GPL_B1 Dynamically active depending on the machine (GPCM, UPMA, or UPMB) 
assigned to control the required slave. 


GPL GPL_A(2: 3)/GPL_B(2:3): Dynamically active depending on the machine 
UPMA or UPMB) assigned to control the required slave. 


GPL_A(2:3)/CS(2:3): Programmed in the SIUMCR. 





eA amically active eepending on the machine (GPCM, UPMB, or PCMCIA 
interface) assigned to control the required slave. 





12 






































rat :3V/GPL_B[2:3)/ 


E 





















ALE_B/DSCK/AT1 
IP_B[0:1}/IWP[0:1]/VFLS[0:1] 
IP_B2/lO1IS16_B/AT2 
IP_B3/IWP2/VF2 
IP_B4/LWP0/VFO 
IP_B5/LWP1/VF1 
IP_B6/DSDI/ATO 
IP_B7/PTR/AT3 

TDI/DSDI 
TCK/DSCK 
TDO/DSDO 


UPWAITA/GPL_A4/AS Programmed in the SIUMCR and MAMR of the memory controller. 


OP2/MODCK2/STS At power-on reset, this functions as MODCK[1:2] 
OP3/MODCK2/DSDO Otherwise, programmed in the SIUMCR and hard reset configuration. 


Programmed in the SIUMCR and hard reset configuration. 
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12.12 PROGRAMMING THE SYSTEM INTERFACE UNIT 


12.12.1 System Configuration and Protection Registers 


12.12.1.1 SIU MODULE CONFIGURATION REGISTER. The SIU module soiiiguiaion 
register (SIUMCR) contains bits that configure various features in the system interface unit. 


SIUMCR_ 


(IMMR & OxFFFFO000) + 0x000 


on 





; (IMMR & OxFFFF0000) + 0x002 


NOTE: The OPAR and PNCS bits swapped places and are now different from the MPC821. 
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EARB—External Arbitration 


If the EARB bit is set, then external arbitration is assumed. If it is cleared, internal arbitration 
is performed. For more information, see Section 13.4.6 Arbitration Phase-Related 
Signals. 


EARP—External Arbitration Request Priority 


This field defines the priority of the external master’s arbitration request. This field is valid 
when EARB is cleared. 000 is the lowest priority level and 111 the highest. For more 
information, refer to Figure 13-20 in Section 13 External Bus Interface. 7 


Bits 4—7, 13, 24, and 28-31—Reserved 
These bits are reserved and should be set to 0. 


DSHW—Data Show Cycles 


This bit selects the show cycle mode to be applied to data cycles. Instruction show cycles 
are programmed in the ICTRL register. The following chart shows the meaning of the bit. 
Refer to Section 20.6.2 Development Port Registers for more information. This bit is 
locked by the DLK bit. 


0 = Disable show cycles for all internal data cycles. 
= Show address and data of all internal data cycles. 
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DBGC—Debug Pin Configuration 


This field configures the debug pin functionality. The default value is set sy the hard reset 
configuration word, as shown in Section 4.3.1.1 Hard Reset Configuration Word. 


00 = IP_B(0:1)/IWP(0:1)/VFLS[0:1] functions as IP_B[0:1]. 
IP_B3/IWP2/VF2 functions as IP_B3. 
IP_B4/LWP0O/VFO functions as IP_B4. 
IP_B5/LWP1/VF1 functions as P_B5. 
OP2/MODCK1/STS functions as OP2. 
ALE_B/DSCK/AT1 functions as ALE_B. 
IP_B2/AT2 functions as IP_B2. 
IP_B6/DSDI/ATO functions as IP_B6. 
IP_B7/PTR/ATS3 functions as IP_B7. 
OP3/MODCK2/DSDO functions as OPS. 

O01 = IP_B[0:1]/IWP(0:1)/VFLS[0:1] functions as IWP[0:1]. 
IP_B38/IWP2/VF2 functions as IWP2. 
IP_B4/LWP0/VFO functions as LWPO. 
IP_B5/LWP1/VF1 functions as LWP1. 
OP2/MODCK1/STS functions as STS. 
ALE_B/DSCK/AT1 functions as AT1. 
IP_B2/AT2 functions as AT2. 
IP_B6/DSDI/ATO functions as ATO. 
IP_B7/PTR/ATS3 functions as AT3. 
OP3/MODCK2/DSDO functions as OP3. 

10 = Reserved. 

11 = IP_B[0:1]/IWP[0:1]/VFLS[0:1] functions as VFLS[0: 1]. 
IP_B3/IWP2/VF2 functions as VF2. 
IP_B4/LWP0O/VFO functions as VFO. 
IP_B5/LWP1/VF1 functions as VF 1. 
OP2/MODCK1/STS functions as STS. 

~- ALE _B/DSCK/AT1 functions as AT1. 
1IP_B2/AT2 functions as AT2. 
IP_B6/DSDI/ATO functions as ATO. 
IP_B7/PTR/ATS3 functions as ATS. 
OP3/MODCK2/DSDO functions as OP3. 
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DBPC—Debug Port Pins Configuration 


This field determines the active pins for the development port. The default value is set ry 
the hard reset eontiguralion word, as shown in Section 4.3.1.1 Hard Reset Configuration 
Word. 


00 = ALE_B/DSCK/AT1 functions as defined by DBGC. 
IP_B6/DSDI/ATO functions as defined by DBGC. 
OP3/MODCK2/DSDO functions as defined by DBGC. 
IP_B7/PTR/ATS functions as defined by DBGC. 
TCK/DSCK functions as DSCK. 
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TDI/DSDI functions as DSDI. 
~ TDO/DSDO functions as DSDO. 

01 = ALE_B/DSCK/AT1 functions as defined by DBGC. 
IP_B6/DSDI/ATO functions as defined by DBGC. 
OP3/MODCK2/DSDO functions as defined by DBGC. 
IP_B7/PTR/ATS functions as defined by DBGC. 
TCK/DSCK functions as TCK. | 
TDI/DSDI functions as TDI. 

TDO/DSDO functions as TDO. 

10 = Reserved. 

11 = ALE_B/DSCK/AT1 functions as DSCK. 
IP_B6/DSDI/ATO functions as DSDI. 
OP3/MODCK2/DSDO functions as OP3. 
IP_B7/PTR/AT3 functions as PTR. 

TCK/DSCK functions as TCK. 
TDI/DSDI functions as TDI. 
TDO/DSDO functions as TDO. 


FRC—FRZ Pin Configuration 
This bit configures the functionality of the FRZ/IRQ6 pin. 


0 = FRZ/IRQ6 functions as FRZ. 


1 = FRZ/IRQ6 functions as IRQ6. 


DLK—Debug Register Lock 


If this bit is set, bits 8—15 are locked and writes to those bits are no longer sacioiied: These 
bits are writable in test mode once the internal FRZ signal is asserted, regardless of the state 
of DLK. This bit is cleared by reset. 


OPAR—Odd Parity 


This bit is used to program odd or even parity. It can also be used to apheraic parity errors 
for testing purposes by writing the memory with OPAR = 1 ells ean the memory with 
OPAR = 0. 


PNCS—Parity Enable For Nonmemory Controller Regions 


This bit enables parity generation/checking for memory regions not controlled by the 
MPC823 memory controller. 


DPC—Data Parity Pins Configuration 
This bit configures the functionality of the DP[O: 3/IRQ3: 6] pins. 


0 = DP[0:3]/IRQ[3:6] functions as IRQ[3:6]. 
1 = DP[0:3)/IRQ[3:6] functions as DP[0:3]. 
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MPRE—Multiprocessors Reservation Enable 


If this bit is set, then the interprocessor reservation protocol is enabled. The RSV pin 
functions as defined in Section 13.4.10 Storage Reservation Protocol. 


O0O= RSV/IRQ2 functions as IRQ2. 
1= RSV/IRQ2 functions as RSV. 


MLRC—Multi-Level Reservation Control 
This field configures the functionality of the KR/RETRY/IRQ4/SPKROUT pins. 


00 = KR/RETRY/IRQ4/SPKROUT functions as IRQ4. 

= KR/RETRY/IRQ4/SPKROUT is three-stated. 
10 = KR/RETRY/IRQ4/SPKROUT functions as KR/RETRY. 
11 =KR/RETRY/IRQ4/SPKROUT functions as SPKROUT. 











AEME—Asynchronous External Master Enable 


This bit configures how the memory controller refers to external asynchronous masters 
initiating a transaction. If this bit is set, the memory controller interprets any assertion on the 
AS pin as an external asynchronous master initiating a transaction. If it is reset, the memory 
controller ignores the value of the AS pin. This bit and the GPLA4DIS bit of the machine A 
mode register controls the direction and functionality of the UPWAITA/GPL_A4/AS pins. 


GPLA4DIS UPWAIT AS VALUE 
VALUE 


SEME—Synchronous External Master Enable 


This bit configures how the memory controller refers to external synchicnels masters 
initiating a transaction. If this bit is set, the memory controller interprets any assertion on the 
TS pin the external bus does not own as an external synchronous master initiating a 
transaction. If it is reset, the memory controller ignores the value of the TS pin when it does 
not own the external bus. When the MPC823 owns the bus, the memory Meee the 
assertion of the TS pin as an internal ea 







GB5E—GPL_B5 Enable 


0 = The BDIP functionality is active. 
1 = The GPL_B5 of the memory controller functionality is active. 


B2DD—Bank 2 Double Drive 
If this bit is set, the CS2 signal is reflected on GPL_x2. 


B3DD—Bank 3 Double Drive 
If this bit is set, the CS3 signal is reflected on GPL_xs. 
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System Interface Unit 


12.12.1.2 INTERNAL MEMORY MAP REGISTER. The internal memory map register 
(IMMR) is located within the PowerPC special register space. It contains the identification of 
a specific device, as well as a base for the internal memory map. Based on the value read 
from this register, the software can deduce the availability and location of any on-chip 
system resource. The contents of this register can be read by the mfspr instruction and the 
ISB field can be written by the mtspr instruction. However, the PARTNUM and MASKNUM 
fields are mask programmed and cannot be changed for any device. 


IMMR 













(IMMR & OxFFFFO000) + 0x638 


PARTNUM MASKNUM 


eres yer ecter ee ar 
(IMMR & OxFFFF0000) + 0x638 


NOTE: * The value depends on the mask revision. 













ISB—Internal Space Base 


This read/write field defines the base address of the internal memory space. The initial value 
of this field can be configured at reset to one of four addresses and changed to any value 
by the software. The number of programmable bits in this field and the resolution of the 
location of internal soace depends on the internal memory space of the specific 
implementation. In the MPC823, you can program all 16 bits. For the information on the 
device’s internal memory map, refer to Section 3 Memory Map and for the available default 
initial values refer to Section 4.3.1.1 Hard Reset Configuration Word. 


PARTNUM—Part Number 


This read-only field is mask programmed with a code corresponding to the ait number of 
the part on which the system interface unit is located. It is intended to help with factory test 
and user code that is sensitive to part refinements. This field changes as the part number 
changes. For example, it would change if a new module is added or if the size of the memory 
module is revised. However, it would not change if the part is revised to fix a bug in an 
existing module. The MPC823 has a part number of 0x20. The other byte of information 
reflects the revision number. Refer to our website for the corresponding revision number for 
your particular version of the silicon. 
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MASKNUM—Mask Number 

This read-only field is mask-programmed with a code corresponding to the mask number of 
the part on which the system interface unit is located. It is intended to help with factory test 
and user code that is sensitive to part refinements. As a result, the value of this field depends 
on the mask revision. 


12.12.1.3 SYSTEM PROTECTION CONTROL REGISTER. The system protection control 
register (SYPCR) controls the system monitors, software watchdog period, and bus monitor 
timing. This register can be read at any time, but can only be written once after system reset. 


SYPCR 


@ 


R/W 
(IMMR & OxFFFFO000) + 0x004 





SYSTEM INTERFACE UNIT | 


® ovene 


(IMMR & OxFFFFO000) + 0x006 





SWTC—Software Watchdog Timer Count — 
This field contains the count value for the software watchdog timer. 


BME—Bus Monitor Enable 


This bit controls the operation of the bus monitor when an internal to external bus cycle is 
executed. 


_Q= Disable the bus monitor. 
1 = Enable the bus monitor. 


Note: If the bus monitor is disabled, the transfer error conditions will not assert the 
TEA pin. 





BMT—Bus Monitor Timing 


This field defines the timeout period, in 8 system clock resolution, for the bus monitor. The 
maximum timeout is 2,040 clocks. | 


Bits 25—27—Reserved 
These bits are reserved and should be set to 0. 


MOTOROLA MPC823 USER’S MANUAL 12-35 


1o2) 
-< 
”n 
— 
rm 
= 
Zz 
— 
m 
“a 
a 
> 
2) 
m 
c 
= 
a 





System Interface Unit 





SWF—Software Watchdog Freeze 


O= The software watchdog timer continues counting even if the FRZ signal is 
asserted. | 
The software watchdog timer stops counting when the FRZ signal is asserted. 


ooh, 
H 


SWE—Software Watchdog Enable 


This bit enables the software watchdog timer. To disable the software watchdog timer, it 
should be cleared by the software after a system reset. 


SWRI—Software Watchdog Reset/Interrupt Select 


O= The software watchdog timer causes a nonmaskable interrupt to the core. 
1 = The software watchdog timer causes a system reset (default). 


SWP—Software Watchdog Prescale 


O= The software watchdog timer is not prescaled. 
1 = The software watchdog timer is prescaled by a factor of 2,048. 


12.12.1.4 TRANSFER ERROR STATUS REGISTER. The transfer error status register 
TESR) contains a bit for each exception source generated by a transfer error. A bit set to 
logic 1 indicates what type of transfer error exception occurred since the last time the bits 
were cleared. The bits are cleared by reset or by writing a 1 to the appropriate bit. Canceled 
speculative accesses that do not cause an interrupt may set these bits. The register has two 
identical sets of fields—one is associated with instruction transfers and the other with data 
transfers. 


TESR 


IMMR & OxFFFFO000) + 0x022 





Bits O-17 and 24—25—Reserved 
These bits are reserved and should be set to 0. — 
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lIEXT—Instruction External Transfer Error Acknowledge 


This bit is set if the cycle is terminated by an externally generated TEA signal when an 
instruction fetch is initiated. 


ITMT—Instruction Transfer Monitor Timeout 


This bit is set if the cycle is terminated by a bus monitor timeout when an instruction fetch is 
initiated. 


IPBO-IPB3—Instruction Parity Error on Bytes 0-3 


There are four parity error status bits for each byte lane. One of these is set for the byte that 
had a parity error when an instruction was fetched. Parity check for a memory region that is 
not controlled by the memory controller is enabled by the PNCS bit in the SIUMCR, as 
shown in Section 12.12.1.1 SIU Module Configuration Register. 


DEXT—Data External Transfer Error Acknowledge 


This bit is set if the cycle is terminated by an externally generated TEA signal when a data 
load or store is requested by an internal master. 


DTMT—Data Transfer Monitor Timeout 


This bit is set if the cycle is terminated by a bus monitor timeout when a data load or store 
is requested by an internal master. 


DPBO—DPB3—Data Parity Error On Bytes 0-3 

There are four parity error status bits for each byte lane. One of these is set for the byte that 
had a parity error when a data load was requested by an internal master. Parity check for a 
memory region that is not controlled by the memory controller is enabled by the PNCS bit in 
the SIUMCR, as shown in Section 12.12.1.1 SIU Module Configuration Register. 
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SECTION 13 
EXTERNAL BUS INTERFACE 


The MPC823 bus is synchronous and burstable. Signals driven on this bus are required to 
make the setup and hold time relative to the bus clock’s rising edge. This bus has the ability 
to support multiple masters. The MPC823 architecture supports byte, half-word, and word 
operands allowing access to 8-,16-, and 32-bit data ports through the use of synchronous 
cycles controlled by the transfer size output (TSIZx) signals. The slave access to 16- and 
8-bit ports is controlled by the memory controller. 


13.1 FEATURES 


The following is a list of the bus interface’s main features: 


26-Bit Address Bus with Transfer Size Indication 
32-Bit Data Bus 

TTL-Compatible Interface 

Internal On-Chip Bus Arbitration Logic Supports One External Bus Master 
Chip-Select and Wait State Generation 
Supports Many Different Memory Types 
Asynchronous DRAM Interface Support 

Flash ROM Programming Support 

Compatible with PowerPC Architecture 
Interfaces to Slave Devices Easily 

Synchronous Bus Operation 

Data Parity Support 
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External Bus Interface 


13.2 TRANSFER SIGNALS 


The bus transfers information between the MPC823 and the external memory or peripheral 
device. External devices can accept or provide 8,16, and 32 bits in parallel and must follow 
the handshake protocol. The maximum number of bits accepted or provided during a bus 
transfer is defined as the port width. 


The MPC823 contains an address bus that specifies the transfer’s address and a data bus 
that transfers the data. Control signals indicate the beginning and type of the cycle, as well 
as the address space and size of the transfer. The selected device then controls the length 
of the cycle with the signal used to terminate the cycle. A strobe signal for the address bus 
indicates the validity of the address and provides timing information for the data. The 
MPC823 bus is synchronous, but the bus and control input signals must be timed to setup 
and hold times relative to the rising edge of the clock. In this situation, bus cycles can be 
completed in two clock cycles. 


Furthermore, for all inputs, the MPC823 latches the level of the input during a sample 
window around the rising edge of the clock signal. This window is illustrated in Figure 13-1, 
where tsu and tho are the input setup and hold times, respectively. To ensure that an input 
signal is recognized on a specific falling edge of the clock, the input must be stable during 
the sample window. If an input makes a transition during the window time period, the level 
recognized by the MPC823 is not predictable. However, the MPC823 always resolves the 
latched level to either a logic high or low before using it. In addition to meeting input setup 
and hold times for deterministic operation, all input signals must obey the protocols 
described in this section. 


CLOCK 


SIGNAL 





SAMPLE 
WINDOW 


Figure 13-1. Input Sample Window 
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13.2.1 Control Signals 


The MPC823 initiates a bus cycle by driving the address, size, address type, cycle type, and 
read/write outputs. At the beginning of a bus cycle, the TSIZO and TSIZ1 signals are driven 
with the AT signals. TSIZO and TSIZ1 indicate the number of bytes to be transferred during 
an operand cycle that consists of one or more bus cycles. These signals are valid at the 
rising edge of the clock in which the TS signal is asserted. The RD/WR signal determines 
the direction of the transfer during a bus cycle. Driven at the beginning of a bus cycle, 
RD/WR is valid at the rising edge of the clock in which the TS signal is asserted. However, 
RD/WR only transitions when a write cycle is preceded by a read cycle or vice versa. The 
signal may remain low for consecutive write cycles. 





wn 
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TS TRANSFER 
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Figure 13-2. MPC823 Bus Signals 
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13.3 BUS SIGNAL DESCRIPTIONS 


The following table decribes each bus interface signal. More detailed descriptions can be 
found in subsequent sections of this manual. 


A(6:31] 26 High 
; 


7 
: 
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Address Bus—Driven by the MPC823 when it owns 
the external bus. It specifies the physical address of 
the bus transaction. These signals can change during 
a transaction when controlled by the memory 
controller. 













Sampled by the MPC823 when an external device 
initiates a transaction and the memory controller was 
configured to handle external master accesses. 





Read/Write—Driven by the MPC823 along with the 
address when it owns the external bus. Driven high 
indicates that a read access is in progress and driven 
low indicates that a write access Is in progress. 


















Sampled by the MPC823 when an external device 
initiates a transaction and the memory controller was 
configured to handle external master accesses. 


Burst Transfer—Driven by the MPC823 along with 

the address when it “owns” the external bus. Driven 

low indicates that a burst transfer is in progress and 

even high indicates that the current transfer is not a 
urst. 


Sampled by the MPC823 when an external device 
initiates a transaction and the memory controller was 
configured to handle external master accesses. 


Transfer Size—Driven by the MPC823 along with the 
address when it owns the external bus. It specifies the 
data transfer size for the transaction. 







Sampled by the MPC823 when an external device 
initiates a transaction and the memory controller was 
configured to handle external master accesses. 





Address Type—Driven by the MPC823 along with 
the address when it owns the external bus. It provides 
additional information about the address on the 
current transaction. 


Used only for testing purposes. 


Reservation Transfer—Driven by the MPC823 along 
with the address when it owns the external bus. It 

rovides additional information about the address on 
he current transaction. 


Used only for testing purposes. 


Program Trace—Driven by the MPC823 along with 
the address when it owns the external bus. It provides 
additional information about the address on the 
current transaction. 


Used only for testing purposes. 
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Table 13-1. Bus Interface Signals (Continued) 


Burst Data In Progress—Driven by the MPC823 
when it owns the external bus. It is part of the burst 

rotocol. Asserted indicates that the second beat in 
ront of the current one is requested by the master. 
This signal is negated prior to the end of a burst to 
terminate the burst data phase early. 
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Transfer Start—Driven by the MPC823 when it owns 
the external bus.It indicates the start of a transaction 
on the external bus. 


Sampled by the MPC823 when an external device 
initiates a transaction and the memory controller was 
configured to handle external master accesses. 


Special Transfer Start—Driven by the MPC823 
when it owns the external bus. It indicates the start of 
a transaction on the external bus or an internal 
transaction in show cycle mode. 


; ee ORES 


Kill Reservation/Retry—When a bus cycle is 


initiated by a stwex instruction that was issued by the 
core to a nonlocal bus on which the storage 
reservation has been lost, this Sane is used by the 
nonlocal bus interface to back-off the cycle. Refer to 
Section 13.4.10 Storage Reservation Protocol. 


For a regular transaction, this ey is driven by the 
slave device to indicate that the MPC823 has to 
relinquish ownership of the bus and retry the cycle. 


D[0:31] 32 High /O {Data Bus—The data bus has the following byte lane 
: assignments: | 
Data Byte Byte Lane 
D(0:7) 0 
D(8:15) 1 . 
D(16:23) 
| D(24:31) 3 
Driven by the MPC823 when it owns the external bus 
and has initiated a write transaction to a slave device. 
For single beat transactions, if external A(6:31) and 
TSIZ(0:1) do not select the byte lanes for transfer, 
they will not supply valid data. 
Driven by the slave in a read transaction. For single 
beat transactions, if external A(6:31) and TSIZ(0:1) do 
not select the byte lanes for transfer, they will not be 
sampled by the MPC823. It is also sampled by the 
MPC823 when the external master acquires the bus. 
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Table 13-1. Bus Interface Signals (Continued) 


MNEMONIC } PINS ACTIVE eee DESCRIPTION : 


DP[0:3] 4 Parity Bus—Each parity signal corresponds to each 
| one of the data bus lanes: 


Data Bus Byte _— Parity Line 
D(0:7) DPO 
D(8:15) DP1 
D(16:23) DP2 
D(24:31) DP3 














=> Mm 
sx 
m= 
so LL 
7 2 
>= 
rota 
mi" 

w 

Cc 

op) 







Driven by the MPC823 when it owns the external bus 
and has Initiated a write transaction to a slave device. 


Each parity signal has the parity value (even or odd) 
of the corresponding data bus byte. For single beat 

transactions, if external A(6:31) and TSIZ(0:1) do not 
select the byte lanes for transfer, they will not have a 
valid parity line. 









Driven by the slave in a read transaction. Each parity 
signal is sampled by the MPC823 and checked (if 
enabled) against the expected value parity value 
(even or odd) of the corresponding data bus byte. For 
single beat transactions, if external A(6:31) and 
TSIZ(0:1) do not select the byte lanes for transfer, | 
they will not be sampled by the MPC823 and its parity 
signals will not be checked. | | 


sess 




























Transfer Acknowledge—Driven by the slave device 
the current transaction was addressed to. It indicates 
that the slave has received the data on the write cycle 
or returned the data on the read cycle. If the 
transaction is a burst, TA should be asserted for each 
one of the transaction beats. 


Driven by the MPC823 when the slave device is 
controlled by the on-chip memory controller. 


Transfer Error Acknowledge—Driven by the slave 
device the current transaction was addressed to. It 

indicates that an error condition has occurred during 
the bus cycle. 


Driven by the MPC823 when the internal bus monitor 
detects an erroneous bus condition. 


Burst Inhibit—Driven by the slave device the current 
transaction was addressed to. It indicates that the 
current slave does not support burst mode. 


Driven by the MPC823 when the slave device is 
controlled by the on-chip memory controller. 














13-6 MPC823 USER’S MANUAL MOTOROLA 


External Bus Interface 


Table 13-1. Bus Interface Signals (Continued) 


MNEMONIC~ . } PINS | ACTIVE /O DESCRIPTION 


1 Low Bus Request—When the internal arbiter is asserted, 
it indicates that an external master is requesting the 
us. 
Driven by the MPC823 when the internal arbiter is 
disabled and the chip is not parked. 


BG 1 Low Bus Grant—When the internal arbiter is enabled, the 
MPC823 asserts this signal to indicate that an 
external master can assume ownership of the bus and 
begin a bus transaction. The BG signal should be | 
qualified by the master requesting the bus to ensure it 
is the bus owner: 

Qualified BG = BG & ~ BB 

When the internal arbiter is disabled, the BG is 
sampled and properly qualified by the MPC823 when 
an external bus transaction is to be executed by the 
chip. | 


BB Bus Busy—When the internal arbiter is enabled, the 
MPC823 asserts this signal to indicate that it is the 
current owner of the bus. When the internal arbiter is 
disabled, it will assert this signal after the external _ 
arbiter grants the chip ownership of the bus and it is 
ready to start the transaction. 


When the internal arbiter is enabled, the MPC823 
samples this signal to get an indication_of when the 
external master ended its bus tenure (BB negated). 
When the internal arbiter is disabled, the BB is 
sampled to properly qualify the BG line when an 
external bus transaction is to be executed by the chip. 





NOTE: O indicates an output from the MPC823 and | indicates an input. 


13.4 BUS INTERFACE OPERATION 


The MPC823 generates a system clock output (CLKOUT) that sets the frequency of 
operation for the bus interface. Internally, the MPC823 uses a phase-lock loop (PLL) circuit 
to generate a master clock for all of the core circuitry, which is phase-locked to the CLKOUT 
output signal. 


All signals for the MPC823 bus interface are specified with respect to the rising-edge of the 
external CLKOUT and are guaranteed to be sampled as inputs or changed as outputs with 
respect to that edge. Since the same clock edge is referenced for driving or sampling the 
bus signals, the possibility of clock skew could exist between various modules in a system 
because of routing or using multiple clock lines. It is your responsibility to handle any clock 
skew problems that could occur as a result of layout, lead-length, and physical routing. 
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External Bus Interface 


13.4.1 Basic Transfers — 


The basic transfer protocol defines the sequence of actions that must occur on the MPC823 
bus to perform a complete bus transaction. The enronologice! sequence or phase of a typical 
bus transfer is as follows: 

Arbitration 

Address transfer 

Data transfer 


ea OO Ne 


~ Termination 


This protocol provides for an arbitration phase and an address and data transfer phase. The 
arbitration phase specifies the master that initiates the next transaction. The address phase 
specifies the address for the transaction and the transfer attributes that describe the 
transaction. The data phase performs the transfer of data. It can transfer a single beat of 
data (4 bytes or less) for nonburst operations, a 4-beat burst of data, an 8-beat burst of data, 
or a 16-beat burst of data. 


13.4.2 Single Beat Transfers 


During the data transfer phase, data is transferred from master to slave on write cycles or 
from slave to master on read cycles. On a write cycle, the master drives the data as soon 
as it can, but never before the cycle following the address transfer phase. The master has 
to take into consideration the “one dead clock cycle” when switching between drivers to 
avoid electrical contention. The master can stop driving the data bus as soon as it samples 
the TA line asserted on the rising edge of the CLKOUT. On a read.cycle the master accepts 
the data bus contents as valid at the rising edge of the CLKOUT in which the TA signal is 
sampled asserted. 
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13.4.2.1 SINGLE BEAT READ FLOW. The basic read cycle begins with a bus arbitration, 
followed by the address transfer and the data transfer. The handshakes are illustrated in the 
following diagrams as applicable to the fixed transaction protocol. 


MASTER SLAVE 
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REQUEST BUS (BR) 


13 


RECEIVES BUS GRANT (BG) FROM ARBITER 





ASSERTS BUS BUSY (BB) IF NO OTHER MASTER IS DRIVING 
| ASSERT TRANSFER STAR Ry foe 
DRIVES ADDRESS AND ATTRIBUTES 


RECEIVES ADDRESS 
RETURNS DATA 
ASSERTS TRANSFER ACKNOWLEDGE (TA) 


RECEIVES DATA 


Figure 13-3. Basic Flow Diagram of a Single Beat Read Cycle 
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2m BR | | | | | | 
mm = | | | | 
Ee BG | | RECEIVE BUS GRANT AND BUS BUSY|NEGATED 
O= 
mi we, 
@ = eb |ASSERT BB, DRIVE ADDRESS AND ASSERT TS 
Cc BB ’ 
a | eee | | | 
A(6:31] | | OC ae ee 
RD/WR | | : | | 


TSIZ[O:1],AT[0:3] | | ieee | 
Baa Reese 


ee 





DATA IS VALID 


Figure 13-4. Single Beat Read Cycle—Basic Timing—Zero Wait States 
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CLKOUT | | | 





(op) 
| | | | | | m 
BR a, 
| | / | | | | Sa 
rt 
| | | | | i 
BG | | RECEIVE BUS GRANT AND BUS BUSY NEGATED | | nz 
| cf = 
55 ND, IASSERT BB, DRIVE ADDRESS AND ASSERT TS | 
| | | | | 
| | O 
Al6:31] | | Sees | 
| | | 
RD/WR | | | | | | 


| 
| 
DATA | 
| 






WAIT STATE 


DATA IS VALID 


Figure 13-5. Single Beat Read Cycle—Basic Timing—One Wait State 
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13.4.2.2 SINGLE BEAT WRITE FLOW. The basic write cycle begins with a bus arbitration, 
followed by the address transfer and the data transfer. The handshakes are illustrated in 
Figure 13-6, Figure 13-7, Figure 13-8, and Figure 13-9 as applicable to the fixed transaction 
protocol. | | | 3 


MASTER | | | SLAVE 


Y 


REQUEST BUS (BR) 


Y 


RECEIVES BUS GRANT (BG) FROM ARBITER 


y 


ASSERTS BUS BUSY (BB) IF NO OTHER MASTER IS DRIVING 


ASSERT TRANSFER START (TS) 
DRIVES ADDRESS AND ATTRIBUTES 





RECEIVES ADDRESS 


DRIVES DATA RECEIVES DATA 


ASSERTS TRANSFER ACKNOWLEDGE (TA) 


STOPS DRIVING DATA 


Figure 13-6. Basic Flow Diagram of a Single Beat Write Cycle 
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BA | | / | | | | a wy 
| | | | | | 2 < 
| | | | | uu ui 
BG | | >» RECEIVE BUS GRANT AND BUS BUSY NEGATED | | nz 
| cf 
C1 as Spey 
i aD, [ASSERT BB, DRIVE ADDRESS AND ASSERT TS | (C9 
| | wre | | | 
| | ] 
Al6:31] | | ces | | 
| | | | 
a | | 
RDWR | | | | | | 


mom 
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Figure 13-7. Single Beat Write Cycle—Basic Timing—Zero Wait States 


DATA IS SAMPLED 
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CLKOUT | | 


@ 


=> mi 
sx 
tes) 
Ru. | | | | | | 
OF 
far | | | | | | 
B BG | sg RECEIVE BUS GRANT AND BUS BUSY NEGATED | | 
, 2 
OF _ |ASSERT BB, DRIVE ADDRESS AND ASSERT TS | 





. a a | | | 


RDAWR | | | | | | 


A(6:31] 


| | | | 
| | 
| | | | | | | 


WAIT STATE 






DATA IS SAMPLED 


Figure 13-8. Single Beat Write Cycle of One Wait State — 
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A typical single beat transfer assumes that the external memory has a 32-bit port size. The 
MPC823 provides an effective mechanism for interfacing with 16-bit port size memories and 
8-bit port size memories, thus allowing transfers to these devices when they are controlled 
by the internal memory controller. The port size (PS) timing shown in the following figures is 
representative of the PS field in Section 15 Memory Controller. 


CLKOUT | | | 


A(6:31] 


> 
> 
+ 
No 


RD/WR 


a a 


STS | 
| 
| | ABCDEFGH | EFGHEFGH 3 | 
| | | | 
TA | | | | 
| | | | 
| | | | 
; 


Figure 13-9. Single Beat, 32-Bit Data, Write Cycle From a 16-Bit Port Size 
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13.4.3 Burst Transfers 


The MPC823 uses burst transfers to access 16-byte operands. A burst accesses a block of 
16 bytes that must be aligned to a 16-byte memory boundary by supplying a starting address 
that points to the critical words and requiring the memory device to sequentially drive/sample 
each word on the data bus. The selected slave device must internally increment the external 
A[28:29] signal (or A[30] for a 16-bit port size slave device) of the supplied address for each 
transfer, thus causing the address to wrap around at the end of the 4-word block. The 
address and transfer attrioutes supplied by the MPC823 remain stable during the transfers 
and the selected device terminates each transfer by aiming Semple the word on the data 
bus and asserting the TA signal. 


The MPC823 also supports burst-inhibited transfers for slave devices that are unable to 
support bursting. For this type of bus cycle, the selected slave device supplies/samples the 
first word the MPC823 points to and asserts the BI signal with TA for the first transfer of the 
burst access. The MPC823 responds by terminating the burst and accessing the remainder 
of the 16-byte block, thus using three read/write cycle bus (each one for a word) for a 32-bit 
port width slave, seven read/write cycle bus for a 16-bit port width slave, or fifteen read/write 
cycle bus for an 8-bit port width slave. 


Burst transfers assume that the external memory has a 32-bit port size. The MPC823 
provides an effective mechanism for interfacing with 16- and 8-bit port size memories that 
allow burst transfers to these devices when they are controlled by the internal memory 
controller. The MPC823 attempts to initiate a burst transfer as normal. If the slave device 
responds to a cycle prior to the TA signal for the first beat, its port size is 8 or 16 bits and the 
MPC823 completes a burst of 8- or 16-bit beats. Effectively, each of the data beats of the 
burst transfers only 1 or 2 bytes. This 8- or 16-beat burst is also considered an atomic 
transaction, so the MPC823 will not allow other unrelated master accesses or bus arbitration 
to intervene between the transfers. 


13.4.4 The Burst Mechanism 


The MPC823 burst mechanism consists of one signal indicating that the cycle is a burst 
cycle, one indicating the duration of the burst data, and another signal indicating whether 
the slave is burstable. These signals are in addition to the basic signals of the bus. At the 
start of the burst transfer, the master drives the address, address attributes, and BURST 
signal to indicate that a burst transfer is being initiated, along with the assertion of the TS 
signal. If the slave is burstable, it negates the BI signal. If the slave cannot burst, it must 
assert the BI signal. During the data phase of a burst write cycle the master drives the data. 
It also asserts the BDIP signal if it intends to drive a subsequent data beat after the current 
data beat. When the slave has received the data, it asserts the TA signal to let the master 
know it is ready for the next data transfer. The master again drives the next data and asserts 
or negates the BDIP signal. If the master does not intend to drive another data beat after the 
current one, it negates the BDIP signal to let the slave know that the next subsequent data 
beat transfer is the last data of the burst write transfer. During the data phase of a burst read 
cycle, the master receives data from the addressed slave. If the master needs more than 
one data, it asserts the BDIP signal. When the data is received prior to the last data, the 
master negates the BDIP signal. Thus, the slave stops driving new data after it receives the 
negation of the BDIP signal at the rising edge of the clock. See Figure 13-10 for details. 
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Figure 13-10. Basic Flow Diagram Of A Burst Read Cycle 
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Figure 13-11. Burst-Read Cycle—32-Bit Port Size—Zero Wait State 
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Figure 13-12. Burst-Read Cycle—32-Bit Port Size—One Wait State 
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Figure 13-13. Burst-Read Cycle—32-Bit Port Size—Wait States Between Beats 
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Figure 13-14. Basic Flow Diagram of a Burst Write Cycle 
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Figure 13-16. Burst-Write Cycle—32-Bit Port Size—Zero Wait States 
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Figure 13-17. Burst-Inhibit Cycle—32-Bit Port Size 
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13.4.5 Transfer Alignment and Packaging 


The MPC823 external bus only supports natural address alignment that forces the following 
restrictions: 


e Byte access can have any address alignment 

e Half-word access must have address bit 31 equal to 0 
e Word access must have address 30-31 equal to 0 

e For burst access must have address 30-31 equal to 0 


The MPC823 can perform operand transfers through its 32-bit data port. If the transfer is 
controlled by the internal memory controller, the MPC823 can support 8- and 16-bit data port 
sizes. The bus requires that the portion of the data bus used for a transfer to or from a 
particular port size to be fixed. A 32-bit port must reside on data bus bits 0-31, a 16-bit port 
must reside on bits 0-15, and an 8-bit port must reside on bits 0-7. The MPC823 always tries 
to transfer the maximum amount of data on all bus cycles and for a word operation it always 
assumes that the port is 32 bits wide at the beginning of the bus cycle. In Figure 13-18 and 
Figure 13-19 and Table 13-2 and Table 13-3, the following operand conventions have been 
adopted: 


e OPO is the most-significant byte of a word operand and OP3 is the least-significant byte. 


e The two bytes of a half-word operand are OPO (most-significant) and OP1 or OP2 
(least-significant) and OP3, depending on the address of the access. 


e The single byte of a byte-length operand is OPO, OP1, OP2, or OP3, depending on the 
address of the access. | 


Note: Although this is a 32-bit machine, only 26 of the bits are visible outside the chip. 





0 . 31 


HALF-WORD 


BYTE 





Figure 13-18. Internal Operand Representation | 
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Figure 13-19 illustrates the device connections on the data bus. 
INTERFACE 


> OUTPUT 
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D(24:31) 


32-BIT PORT SIZE 


16-BIT PORT SIZE 


_ 8-BIT PORT SIZE 


Figure 13-19. Interface To Different Port Size Devices 


Table 13-2 lists the bytes for read cycles required on the data bus. 


Table 13-2. Data Bus Requirements For Read Cycles 


TRANSFER | TSIZE | INTERNAL 32-BIT PORT SIZE 16-BIT PORT SIZE 
SIZE [0:1] | ADDRESS | 


_[si[ si [voor [een [ cos [sans [vom [oe [vom 





NOTE: — Denotes that a byte is not required during that read cycle. 
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Table 13-3 lists the patterns of the data transfer for write cycles when accesses are initiated 
by the MPC823. 


Table 13-3. Data Bus Contents for Write Cycles 


INTERNAL EXTERNAL DATA BUS PATTERN 
ADDRESS 


TRANSFER TSIZE 
SIZE [0:1] 
coor] voor [ oro | owen [ ooo 
eee 
oe 


Half-Word 





7) 
=> 
On 
zo 
Sa. 
oc 
Co 
UY inj 
xi 
He 






NOTE: — Denotes that a byte is not required during that read cycle. 


13.4.6 Arbitration Phase-Related Signals 


The external bus design provides for a single bus master, either the MPC823 or an external 
device. One or more of the external devices on the bus has the capability of becoming bus 
master for the external bus. Bus arbitration may be handled either by an external central bus 
arbiter or by the internal on-chip arbiter. In the latter case, the system is optimized for one 
external bus master besides the MPC823. The arbitration configuration (external or internal) 
is set at system reset. See Section 15.6 External Master Support for more information. 


Each bus master must have BR, BG, and BB signals. The device that needs the bus asserts 
the BR signal. The device then waits for the arbiter to assert the BG signal. In addition, the 
new master must look at the BB signal to ensure that no other master is driving the bus 
before it can assert BB and assume ownership of the bus. If the arbiter has taken the BG 
away from the master and the master wants to execute a new cycle, the master must 
rearbitrate before a new cycle can be initiated. The MPC823, however, guarantees data 
coherency for burst accesses to a small port size. This means that the MPC823 will not 
release the bus until the transactions em) complete. 
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Figure 13-20 describes the basic protocol for bus arbitration. For more information, see 
Section 12.12.1.1 SIU Module Configuration Register. 
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Figure 13-20. Bus Arbitration Flowchart 


13.4.6.1 BUS REQUEST SIGNAL. The potential bus master asserts the BR signal to 
request bus mastership. BR should be negated once the bus is granted, the bus is not busy, 
and the new master can drive the bus. If more requests are pending, the master can keep 
asserting its bus request as long as needed. When configured for external central 
arbitration, the MPC823 drives this signal when it needs bus mastership. When the internal 
on-chip arbiter is used, this signal is an input to the internal arbiter and should be driven by 
the external bus master. 


13-28 MPC823 USER’S MANUAL MOTOROLA 


External Bus Interface 


13.4.6.2 BUS GRANT SIGNAL. The BG signal is asserted by the arbiter to indicate that the 
bus is granted to the requesting device. The BG signal can be negated after BR is negated. 
The current bus master may choose to keep BG asserted to park the bus and maintain 
ownership without rearbitrating until another master makes a request. This reduces 
arbitration time, which then improves performance. When configured for external central 
arbitration, the BG becomes an input signal to the MPC823 from the external arbiter. When 
the internal on-chip arbiter is used, this signal is an output from the internal arbiter to the 
external bus master. 


13.4.6.3 BUS BUSY SIGNAL. The BB signal indicates that the current bus master is using 
the bus. New masters should not begin transferring until this signal is negated. The bus 
owner should not relinquish or negate this signal until its transfer is complete. To avoid 
contention on the BB signal, masters should three-state this signal when it gets a logical 1 
value. This situation implies that the connection of an external pull-up resistor is needed to 
ensure that a master acquiring the bus recognizes that the BB signal is negated, regardless 
of how many cycles have passed since the previous master relinquished the bus. Refer to 
Figure 13-21 for more information. 
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Figure 13-21. Basic Bus Biigy earhecicn 
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Figure 13-22. Bus Arbitration Timing Diagram 


At system reset, the MPC823 can be configured to use the internal bus arbiter and it will be 
parked on the bus. The priority of the external device relative to the internal MPC823 bus 
masters is programmed in the SIU module configuration register, as shown in 

Section 12.12.1.1 SIU Module Configuration Register. If the external device requests the 
bus and the MPC823 does not need it or the external device has priority over the current 
internal bus master, the MPC823 grants the bus to the external device. Figure 13-23 
illustrates the internal finite state machine that implements the arbiter protocol. 
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Figure 13-23. Internal Bus Arbitration State Machine 


13.4.7 Address Transfer Phase-Related Signals 


13.4.7.1 TRANSFER START SIGNAL. The TS signal indicates the beginning of a cycle 
initiated by the bus master. This signal should be asserted by a master only after ownership 
of the bus is granted by the arbitration protocol. This signal is only asserted for the first clock 
cycle of the transaction and is negated in the successive clock cycles. The master should 
three-state this signal when it relinquishes the bus to avoid contention between two or more 
masters in this signal. This configuration requires an external pull-up resistor to be 
connected to the TS signal. This will prevent a slave from responding to a bogus TS 
assertion. Refer back to Figure 13-21 for more information. 
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13.4.7.2 ADDRESS BUS. The 26-bit address bus consists of address bits 0-25 and Bit 6 
is most-significant. The bus is byte addressable, so each address can address one or more 
bytes. The address and its attributes are driven on the bus with the TS signal and stay valid 
until the bus master received a TA signal from the slave. To distinguish the individual byte, 
the slave device must observe the TSIZx signals. 


w A Note: Although this is a 32-bit machine, only 26 of the bits are visible outside the chip. 


13.4.7.3 TRANSFER ATTRIBUTES. The transfer attributes consist of the RD/WR, 
BURST, TSIZx, ATx, STS, and BDIP signals. These signals, except for the BDIP, are 
available at the same time as the address bus. 





13.4.7.3.1 Read/Write Signal. When the RD/WR signal is high it indicates a read access 
and when it is low it indicates a write access. 


13.4.7.3.2 Burst Signal. The BURST signal and the address are driven by the bus master 
at the beginning of the bus cycle to indicate that the transfer is a burst transfer. The burst 
size is always 16 bytes. With a 32-bit port size, the burst includes 4 beats. When its port size 
is 16 bits and controlled by the internal memory controller, the burst includes 8 beats. When 
its port size is 8 bits and controlled by the internal memory controller, the burst includes 16 
beats. The MPC823 bus supports critical data word first for burst. The order of the 
wraparound goes back to the critical word. For example, assuming data 2 is the critical word: 


e Case burst of four beats: 
data 2 = data 3 = data 0 ™ data 1 
e Case burst of eight beats: 


data 2 = data 3 = data 4 = ......... ~™» data 7 data 0 = data 1 
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13.4.7.3.3 Transfer Size Signal. The TSIZx signals indicate the size of the requested data 
transfer and they can be used with the BURST and A[30:31] signals to determine which byte 
lanes of the data bus are involved in the transfer. For nonburst transfers, the TSIZx signals 
specify the number of bytes starting from the byte location addressed by the A[30:31] 
signals. In burst transfers, the value of the TSIZx signal is always 00. 


Table 13-4. BURST/TSIZE Encoding 


BURST TSIZx TRANSFER SIZE 
Half-Word 


Burst (16 bytes) 


13.4.7.3.4 Address Space Attributes. The address space attributes consist of the 
address type (AT[0:3]), PTR, and RSV signals, which are all outputs that indicate one of 16 
“address types” to which the address applies. These types are designated as either a 
normal/alternate master cycle, problem/privilege (user or Supervisor), and instruction or data 
types. The address space signals are valid at the rising edge of the clock in which the STS 
signal is asserted. 








Address space signals reflect the current status of the master originating the access, not 
necessarily the status in which the original access to this location has occurred. An example 
of this situation is when a copyback of a dirty line in the data cache occurs after the privilege 
state of the processor has been changed since the last access to the same line. Functional 
usage of the ATx, PTR, and RSV signals is for the reservation protocol described in 
Section 13.4.10 Storage Reservation Protocol. Table 13-5 provides the space definition 
encoded by the STS, TS, ATx, PTR, and RSV signals. 


Show cycles are accesses to the core’s internal bus devices. These accesses are driven 
externally for emulation, visibility, and debugging purposes. A show cycle can have one 
address phase and one data phase (or just an address phase for the instruction show 
cycles). The cycle can be a write or read access and the data for both the read and write 
accesses should be driven by the bus master. This is different than the normal bus read and 
write accesses. The address of the show cycle should be valid on the bus for one clock and 
the data of the show cycle should be valid on the bus for one clock. The data phase should 
not require a transfer acknowledge to terminate the bus-show cycle. In a burst show cycle 
only the first data beat will be shown externally. 


13.4.7.3.5 Special Transfer Start Signal. The STS signal is driven by the MPC823 when 
it owns the external bus. It indicates the start of a transaction on the external bus or an 
internal transaction in show cycle mode. 
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Table 13-5. Address Space Definitions 
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Table 13-5. Address Space Definitions (Continued) 


CORE/CPM PROBLEM STATE/ 
PRIVILEGE STATE 


HE | 





INSTRUCTION/ 


DATA 





Core, Show Cycle Address Instruction, Program 
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PROGRAM TRACE 
TRACE 
race 
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Privilege State 


1 1 1 Core, Show Cycle Address Instruction, Privilege 
State 
a ae ae Core, Reservation Show Cycle Data, Privilege State 


1 Core, Show Cycle Address Instruction, Program 
Trace, 
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1 1 1 Core, Show Cycle Address Instruction, Problem 
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i ee ae Core, Reservation Show Cycle Data, Problem State 


No Core, Show Cycle Data (CH indicates channel 
number) 
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13.4.7.3.6 Burst Data in Progress Signal. The BDIP signal is sent from the master to the 
slave to indicate that there is a data beat following the current data beat. The master uses 
this signal to give the slave advanced warning of the remaining data in the burst. By negating 
the BDIP signal, you can terminate a burst cycle early. Refer to Section 13.4.2 Single Beat 
Transfers and Section 13.4.4 The Burst Mechanism for more information. 





13.4.8 Data Transfer Phase-Related Signals 


13.4.8.1 DATA SIGNAL. The D[0:31] signals are driven by the MPC823 when it owns the 
external bus and has initiated a write transaction to a slave device. During a read transaction 
the D[0:31] signals are driven by the slave device. See Table 13-2 for byte lane 
assignments. 


13.4.9 Termination Phase-Related Signals 


13.4.9.1 TRANSFER ACKNOWLEDGE SIGNAL. The TA signal indicates the normal 
completion of a bus transfer. During burst cycles, the slave asserts this signal with every 
data beat returned or accepted. This signal should be pulled up to Vpp with a pull-up resistor. 


13.4.9.2 BURST INHIBIT SIGNAL. The BI signal is sent from the slave to the master to 
indicate that the addressed device does not have burst capability. If this signal is asserted 
or equal to 0, the master must transfer in multiple cycles and increment the address for the 


‘slave to complete the burst transfer. For a system that does not use the burst mode at all, 


this signal can be permanently tied low. This signal should be pulled up to Vpp with a pull-up 
resistor. | 


13.4.9.3 TRANSFER ERROR ACKNOWLEDGE SIGNAL. The TEA signal terminates the 
bus cycle under bus error conditions. The current bus cycle should be aborted. This signal 
should override any other cycle termination signals, such as the TA signal. This signal 
should be pulled up to Vpp with a pull-up resistor. 
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13.4.9.4 PROTOCOL FOR TERMINATION SIGNALS. The transfer protocol was defined 
to avoid electrical contention on signals that can be driven by various sources. To do that, a 
slave should not drive signals associated with the data transfer until the address phase is 
completed and it recognizes the address as its own. The slave should disconnect from 
signals immediately after it has acknowledged the cycle and no later than the termination of 
the next address phase cycle. This indicates that the termination signals should be 
connected to power through a pull-up resistor to avoid a situation in which a master samples 
an undefined value in any of these signals when no real slave is addressed. See 

Figure 13-24 and Figure 13-25 for more information. 


nm SLAVE 1 
MPC823 


ACKNOWLEDGE/TERMINATION 
Figure 13-24. Termination Signals Protocol Basic Connection 
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Figure 13-25. Termination Signals Protocol Timing Diagram 
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~13.4.10 Storage Reservation Protocol 


The MPC823 storage reservation protocol supports multilevel bus structure. For each local 
bus, storage reservation is handled by the local reservation logic. The protocol tries to 
optimize reservation cancellation so that a PowerPC processor is notified of storage 
reservation loss on a remote bus only when it has issued a stwex cycle to that address. In 
other words, the reservation loss indication comes as part of the stwex cycle. This method 
avoids the need to have fast Storage reservation loss indication signals routed from every 
remote bus to every PowerPC master. 
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The storage reservation protocol makes the following assumptions: 


e Each processor has, at most, one reservation “flag” 
e lwarx sets the reservation “flag” 


e lwarx by the same processor clears the reservation “flag” related to a previous lwarx 
instruction and again sets the reservation “flag” 


e stwcx by the same processor clears the reservation “flag” 
e A store by the same processor does not clear the reservation “flag” 


e Some other processor (or other mechanism) store to the same address as an existing 
reservation clears the reservation “flag” 


e If the storage reservation is lost it is guaranteed that stwex will not modify the storage 
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The reservation protocol for a single-level (local) bus is illustrated in Figure 13-26. It 
assumes that external logic on the bus performs the following functions: 


Snoops accesses to all local bus slaves 


Holds one reservation for each local master capable of storage reservations 


Sets the reservation when that master issues a load and reserve request 
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Clears the reservation when some other master issues a store to the reservation 
address 
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Figure 13-26. Reservation On Local Bus 
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The local bus interface block implements a reservation “flag” for the local bus master. The 
reservation “flag” is set by the local bus interface when a load with reservation is issued by 
the local bus master and the reservation address is located on the remote bus. The “flag” is 
reset when an alternative master on the remote bus accesses the same location in a write 
cycle. If the MPC823 begins a memory cycle to the previously reserved address (located in 
the remote bus) as a result of a stwex instruction, one of the following conditions can occur: 
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e Ifthe reservation “flag” is set, the local bus interface acknowledges the cycle in a normal 
way. a 





¢ If the reservation “flag” is reset, the local bus interface should assert KR. However, the 
local bus interface should either not perform the remote bus write access or abort it if 
the remote bus supports aborted cycles. The failure of the stwex instruction is reported 
to the core. 7 
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Figure 13-27. Reservation On Multilevel Bus Hierarchy 
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13.4.11 Exception Control Cycles 


The MPC823 bus architecture requires the TA signal to be asserted from an external device 
to indicate that the bus cycle is complete. TA is not asserted when one of the following 
conditions occur: 


e The external device does not respond 
e¢ Other application-dependent errors occur 


The external circuitry can provide TEA when no device responds by asserting TA within an 
appropriate period of time after the MPC823 initiates the bus cycle. This allows the cycle to 
terminate and the processor to enter exception processing for the error condition. 


To properly control termination of a bus cycle for a bus error, TEA must be asserted 
simultaneously or before TA is asserted. TEA should be negated before the second rising 
edge after it was sample-asserted to avoid detecting an error for the next initiated bus cycle. 
TEA is an open-drain pin that allows the wire-OR of any different error generation sources. 


13.4.11.1 RETRY SIGNAL. When an external device asserts the RETRY signal during a 
bus cycle, the MPC823 enters a sequence in which it terminates the current transaction, 
relinquishes ownership of the bus, and retries the cycle using the same address, address 
attributes, and data. Figure 13-28 illustrates the behavior of the MPC823 when the RETRY 
signal is detected as a termination of a transfer. The figure illustrates that when the internal 
arbiter is enabled, the MPC823 negates the BB signal and asserts the BG signal in the clock 
cycle following retry detection. This allows any external master to gain bus ownership. In the 
next clock cycle, a normal arbitration procedure may occur. The figure also shows that the 
external master did not use the bus, so the MPC823 initiates a new transfer with the same 
address and attributes as before. In Figure 13-29 the same situation is illustrated to show 
that the MPC823 is working with an external arbiter. In the clock cycle after the CPU 
recognizes that the RETRY signal is asserted, the BR and BB signals are negated. One 
clock cycle later, the normal arbitration procedure may occur. This input signal requires a 
pull-up resistor. | 
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Figure 13-28. RETRY Transfer Timing—Internal Arbiter 


| 

| 

| | 

DATA | 
| 

| 

| 


13-42 MPC823 USER’S MANUAL MOTOROLA 


External Bus Interface 


CLKOUT | 





, 2 
BR(OUTPUT) | | I 4 | | | | | 26 
| | | | | | | | zat 
oo 
| | | | | Md 
_ <5 
BG | | | | | a= 
i 1 | | | 
5B | | [4 ALLOW EXTERNAL. MASTER | 
| | |TO GAIN THEIBUS | | | 
| | | | 
| | | | 
= | | | 
RD/WR 


om 
| | | | 


| | 
| | 
| | 
| | 


Ye ic 
) aa \\ar a 
salads ET \\\'9 (0 /| 


Figure 13-29. RETRY Transfer Timing—External Arbiter 
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When a burst access is initiated by the MPC823, the bus interface only recognizes the 
RETRY assertion as a retry termination if it detects it before the first data beat is 
acknowledged by the slave device. When the RETRY signal is asserted as a termination 
signal on the second or third data beat of the access, the MPC823 recognizes it as a transfer 
error acknowledgement. 
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Figure 13-30. Retry On Burst Cycle 
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In reference to Figure 13-30, if the BI signal is asserted at the first beat of a burst, then the 
remaining beats of the 16-byte transfer retry are recognized as a transfer error 
acknowledge. Table 13-6 summarizes how the MPC823 recognizes the termination signals 
provided by the slave device that the initiated transfer addressed. 


Table 13-6. Termination Signal Protocol 


Negated Normal Transfer Termination 


Negated Negated Asserted Retry Transfer Termination / Kill 
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SECTION 14 
ENDIAN MODES 


This section will discuss how the MPC823 supports three system endian configurations: 


e Little-endian system 
e Big-endian system 
¢ PowerPC™ little-endian system 


A general description of the different endian modes can be found in The PowerPC 
Microprocessor Family: The Programming Environments (MPCFPE/AD) manual that is 
available from Motorola. Throughout the MPC823 User's Manual, the term system refers to 
the devices that reside on the MPC823 bus. The MPC823 core operates in the big-endian 
mode of a big-endian system and in the PowerPC little-endian mode of two other 
configurations. 


ENDIAN MODES 


9 


Table 14-1. Little-Endian Effective Address Modification 
For Individual Aligned Scalar 


DATA LENGTH (BYTES) ADDRESS MODIFICATION: 





NOTE: There are no 8-byte scalars in the MPC823. 





For programming configurations, refer to the table below. 


Table 14-2. Endian Mode Programming For Core Data Structures 


PowerPC Little-Endian Mode aa ae 
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The hardware operations that are used to support the different endian modes are: 


e Address munging in the core is controlled by the MSR, _ bit. Refer to the PowerPC 
Microprocessor Family: The Programming Environments for 32-Bit Microprocessors 
manual for more information. 


¢ The MPC823 internal bus signal is driven by the master that informs the system 
interface unit to swap and perform address demunging or leave the current access as 
itis. Table 10-1 defines the DC_CSR, ¢z bit for core and cache accesses. 


e Address munging and data bytes format in the communication processor module 
(CPM) that is controlled by the BO field of the function code register. 
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Figure 14-1. General MPC823 System Diagram 


Note: Some peripheral component interconnect (PCI) bridge devices (such as the 
| MPC105/106) cannot be used in little-endian mode. 
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14.1 LITTLE-ENDIAN FEATURES 


The following is a list of the little-endian system’s main features. 


e System Memory Organization and E-Bus Format are Little-Endian 

e U-Bus Data, Instruction and Data Caches, and Internal Memory Format are Big-Endian 
e Data Access Constraints That Follow the PowerPC Little-Endian Rules 

e Same Byte Order Between the Media and System Memory 


e For Core Accesses, Swap and Address Demunging Are Performed By the System 
Interface Unit On the U-Bus To the System Path 

e The Core’s Load/Store Unit Swapper Uses Munged Addresses to Put the Data On the 
Right Byte Lanes When Half-Word or Byte Accesses Are Performed 


e The Communication Processor Module Performs Data Swapping According to 
Information in Buffer Descriptors 


The following tables describe how to handle the little-endian program or data in the 
little-endian system that is built around the MPC823 for various port sizes. 


Table 14-3. Little-Endian Program/Data Path Between the 
Register and 32-Bit Memory 


DATA IN THE U-BUS AND E-BUS FORMAT LITTLE-ENDIAN 
REGISTER CACHES FORMAT | | PROGRAM/DATA 


olsfetstolsfetsfolstele|e [als [o 
Pe fefofe[nfefee[upsfeln—a [ele [ 


Fate 
— 
= 
=— 
=a 
= 


MOTOROLA MPC823 USER’S MANUAL | 14-3 





7) 
ug 
Q 
2) 
= 
z 
=< 
oO 
z 
Li 


© 





Endian Modes 


Table 14-4. Little-Endian Program/Data Path Between the 
Register and 16-Bit Memory 


FETCH/ LITTLE- EXTERNAL DATA IN THE U-BUS AND E-BUS FORMAT LITTLE-ENDIAN 
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Table 14-5. Little-Endian program/Daiai Path Between the 
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14.2 BIG-ENDIAN SYSTEM FEATURES 


The following is a list of the big-endian system’s main features: 


¢ Caches, U-Bus, E-Bus, System Memory, and I/O Organization Format is Big-Endian 
e Same Byte Order Between the Media and System Memory 

e Communication Processor Module Writes and Reads Big-Endian U-Bus Data 

e PCI Bridge Operates in Big-Endian Mode as Needed 


14.3 POWERPC LITTLE-ENDIAN SYSTEM FEATURES 


The following is a list of the PowerPC little-endian system’s main features: 


e Caches, U-Bus, E-Bus, System Memory, and E-Bus Attached I/O Organization Format 
is Big-Endian 

e PCI Bus Format is Little-Endian 

e Data Access Constraints That Follow the PowerPC Little-Endian Rules 


e Address Munging in the Core and Communication Processor Module Follows the 
Guidelines in Table 14-1 


e The PCI Bridge Operates in Little-Endian Mode as Needed. Swap and Address 
Demunging is Performed by the PCI Bridge on the PCI I/O to the System Memory Path. 


e The Stream Hit Mechanisms of the Instruction and Data Caches Operate Less 
Efficiently When Address Munging is Performed on Cache Accesses. Some 
Performance Degradation is Expected When Working in this Mode. 


14.4 SETTING THE ENDIAN MODE OF OPERATION 


The mode should be set early in the reset routine and remain unchanged for the duration of 
system operation. The MPC823 core is in big-endian mode after reset. To switch between 
the different endian modes of operation, the core must run in serialized mode and the 
caches should be disabled. It is not recommended that you switch back and forth between 
modes. To transfer the system to the PowerPC little-endian mode, the MSR,-_ and MSR - 
bits should be changed with the mtmsr instruction that resides on the odd word boundary 
(A[29] = 1). The instruction that is executed next will be fetched from this address plus 8. If 
the instruction resides on an even word boundary (A[29] = 0), then this instruction will be 
executed twice because of address munging. 


The instruction used to transfer the system back to big-endian mode must reside on an even 
word boundary (A[29] = 0). The next instruction will be fetched from this address plus 12. A 
transfer to little-endian mode should be made with the mtspr instruction that resides on the 
even word boundary (A[29] = 0). Further instructions should reside in the little-endian format 
of the external system memory and in the big-endian format of the internal memory. The BO 
field of the function code registers (FCRs) in the communication processor module should 
be set to the required endian format for the buffer descriptor. 
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SECTION 15 
MEMORY CONTROLLER 


The memory controller is responsible for controlling a maximum of eight memory banks 
shared between a general-purpose chip-select machine and a pair of sophisticated 
user-programmable machines. It supports a glueless interface to SRAM, EPROM, flash 
EPROM, regular DRAM devices, self-refresh DRAMs, extended data output DRAM devices, 
synchronous DRAMs, and other peripherals. This flexible memory controller allows you to 
implement memory systems with very specific timing requirements. It supports external 
address multiplexing, periodic timers, and timing generation for row address and column 
address strobes to allow for a glueless interface to DRAM devices. The periodic timers allow 
refresh cycles to be initiated while the address muxing provides row and column addresses. 


You can define different timing patterns for the control signals that govern a memory device. 
These patterns define how the external control signals behave in read-access, write-access, 
burst read-access, or burst write-access requests. You decide how the external control 
signals toggle when the periodic timers reach the maximum programmed value for refresh 
operation. 


15.1 FEATURES 


The following is a list of the memory controllers main features: 


e Eight Memory Banks 


32-bit address decode with mask 

Various block sizes (82K to 4G) 

Byte parity generation/checking 

Write-protection capability 

“Address types” match qualifying memory bank accesses for internal masters 
Timing pattern machine selected according to the type of memory device accessed 
Support for external master access to memory banks 

Synchronous and asynchronous external masters support 


DUOOUUoO?d 


e General-Purpose Chip-Select Machine 


Compatible with SRAM, EPROM, FEPROM, and peripherals 
Global (boot) chip-select available at system reset 

Boot chip-select support for 8-, 16-, and 32-bit devices 

Two clock accesses to external device 

Four byte write enable (WE[0:3]) signals 

Output enable (OE) signal 


Deouoeed 
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Memory Controller 


e Two User-Programmable Machines 


L1 RAM-based machine controls the timing of the external signals with a granularity of 
one quarter of a system clock period 

(1) User-specified patterns run when a single read access, single write access, burst 
read access or burst write access is requested by an internal or external 
synchronous master 


L) User-specified patterns run when a single read access or single write access is 
requested by an external asynchronous master 

{4 UPM periodic timer initiates an automatic pattern when it expires (refresh) 

O User-specified patterns run under software control 

[1 Each UPM can be defined to support DRAM devices with depths of 64K,128K, 
256K, 512K, 1M, 2M, 4M, 8M, 16M, 32M, 64M, 128M, and 256M 

L} Four byte-select lines for each UPM 

Ly Six external general-purpose lines controlled by each UPM 

[1 Supports 8-, 16-, and 32-bit DRAM port sizes 

L} Glueless interface to one bank of DRAM (only external buffers are required for 
additional SIMM banks) 

[1 Page mode support for successive transfers within a burst for all on-chip and 
external synchronous masters 

(i Internal address multiplexing for all on-chip bus masters supporting 64K, 128K, 


256K, 512K, 1M, 2M, 4M, 8M, 16M, 32M, 64M, 128M, 256M page banks 
Li Glueless interface to EDO, self refresh, and synchronous DRAM devices 


A block diagram of the memory controller is illustrated in Figure 15-1. 
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Figure 15-1. Memory Controller Block Diagram (Single UPM) 
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15.2 ARCHITECTURE 


The memory controller consists of three basic machines: 


° General-purpose chip-select machine 
e User-programmable machine A 
e User-programmable machine B 


As illustrated in Figure 15-2, each bank can be assigned to any one of these machines via 
the MS field in the base register. When a memory address matches the BA field of the base 
register, the corresponding machine takes ownership of the external signals that control 
access until the cycle terminates. 
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Figure 15-2. Memory Controller Machine Selection 


The general-purpose chip-select machine (GPCM) provides a glueless interface to EPROM, 
SRAM, Flash EPROM, and other peripherals. General-purpose chip-select signals are 

available on CS[0:7]. CSO also functions as the boot chip-select signal that allows the CPU 
to access the boot EPROM from reset. Each chip-select allows a maximum of 30 wait states. 
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Some features are common to all eight memory banks. The full 32-bit decode is available 
internally, even if all 32 address bits are not visible outside the MPC823. For external master 
transactions, the memory controller extends the 26-bit external address line to 32 bits and 
the six most-significant bits are zero. The variable block size of each memory bank can be 
between 32K and 64M for a total memory capacity of 512M. Parity can be generated and 
checked for any memory bank and each memory bank can be selected for read-only or 
read/write operation. For system protection purposes, you can use certain address type 
codes to cause the memory controller to restrict access to a memory bank. For additional 
flexibility, address type comparisons provide you with a mask option. 


The memory controller functionality helps you design MPC823-based systems with little or 
no glue logic required. In Figure 15-3, CSO is used as the 16-bit boot EPROM with the MS 
field of the base register 0 (BRO) configured to select the GPCM. CS$1 is used as the RAS 
signal for 32-bit DRAM with the MS field of base register 1 (BR1) configured to select UPMA. 
The BS_A signals are used as CAS signals on the DRAM. 


ADDRESS 


MPC823 


DP[0:3] 





Figure 15-3. Simple System Configuration 
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The two user-programmable machines (UPMA and UPMB) in the memory controller provide 
a flexible interface to many types of memory devices. Each UPM can control the address 
multiplexing necessary to access DRAM devices, the timing of the BS signals, and the 
timing of the GPLx signals. Each memory bank can be assigned to either UPM. There are 
a total of eight CSx signals that can be split between the two UPMs. 





Each user-programmable machine is a RAM-based machine controlled by software. The 
software toggles the memory controller external signals when an external single word 
read/write access or an external burst read/write access is initiated by an internal or external 
master. The UPM also controls address multiplexing, address increment, and transfer 
acknowledge assertion for a specific memory access. The UPM can be programmed to run 
a specific signal pattern for a certain duration of clock cycles. At every clock cycle, the logical 
value of the external signals specified in the RAM array is output on the corresponding UPM 
pins. , | 


When a new access to external memory is requested by any of the internal or external 
masters, the address of the transfer and the address type is compared to each one of the 
valid banks defined in the memory controller. Notice that all of the A[0:16] and AT[0:2] 
signals are maskable. When an address match is found in one of the memory bank 
chip-select ranges, the corresponding MS field in the base register defines the machine that 
handles the memory access. See Figure 15-4 for details. 


The memory controller provides four parity (DP[0:3]) signals, one for each data byte lane on 
the MPC823 system bus. The parity on the bus is only checked if the memory bank 
accessed in the current transaction has parity enabled. Parity checking/generation can be 
enabled for a specific memory bank in the base register. The type of parity is defined in the 
system interface unit module configuration register, which is explained in 

Section 12.12.1.1 SIU Module Configuration Register. Also, system protection is 
provided by defining each memory bank as read-only or read/write. 
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EXTERNAL SIGNALS 


Figure 15-4, Basic Memory Controller Operation 


15.3 REGISTER MODEL 


The status bits for each one of the memory banks are in the memory controller status 
(MSTAT) register, which is used by the entire memory controller. Each of the eight memory 
banks has a base register (BRx) and an option register (ORx). The MSTAT reports write- 
protect violations that occur and parity errors for every bank. The base register contains a V 
bit that indicates when the information for the chip-select is valid. 


Each base register defines the starting address of its memory bank and each option register 
defines the attributes for its memory bank. The option registers also define the initial address 
multiplexing for a memory cycle controlled by a UPM. The machine A mode register (MAMR) 
and machine B mode register (MBMR) define most of the global features for the 
user-programmable machines. 


The memory command register (MCR) and memory data register (MDR) are used to 
initialize the UPM’s RAM array. The memory address register (MAR) specifies the location 
in the RAM array to be executed as defined by the MCR. It also allows a specific address 
pattern to be output onto the A[6:31] signals. The memory periodic timer prescaler register 
_ (MPTPR) defines the divisor of the BRGCLK used as the memory periodic timer input clock. 
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Memory Controller 


The memory controller registers are used by the general-purpose chip-select machine and 
the user-programmable machines as specified in Table 15-1. See Section 15.3.1 Register 
Descriptions for specific register information. 


Table 15-1. Memory Controller Register Usage 


ee 
[enten Raster Bank 7 Reoer(ond [dT 
[weno Statin Reser wsrany | 
[—Werory Command Reser | 
[wach Anode Reosertuaney | 
[— wacine ose Reser rewry | 

| 

Leeeenal 








ae 










Memory Data Register (MDR) 
Memory Address Register (MAR) 
Memory Periodic Timer Prescaler Register (MPTPR) 


The memory controller supports multiple port sizes. Predefined 8-bit ports can be accessed 
as odd or even bytes, predefined 16-bit ports can be accessed as odd or even bytes and 
even half-words on data bus bits 0 through 15. Predefined 32-bit ports can be accessed as 
odd bytes, even bytes, odd half-words, even half-words, or words on word boundaries. The 
port size is specified by the PS field in the base register. 





The WP bit of the base register restricts write accesses to a certain address range. If you try 
to write in this area, a write-protect violation occurs and the WPER bit in the memory status 
register is set. 


Each time an internal or eqeial bus cycle access is requested, the address and its 
corresponding address type are compared to each one of the banks. If a match is found on 
one of the memory controller banks, the attributes defined for that bank in the base and 
option registers are used to control the memory access. However, if multiple matches are 
found, the lowest numbered matched bank handles the memory access. It should be noted 
that when external masters access memory controller-managed slaves on the bus, the 
internal AT signals to the memory controller are forced to “100°. 


Parity can be configured for any bank. It is generated and checked on a per-byte basis using 
the DP[0:3] signals for the bank if the PARE bit is set in the base register. The OPAR bit in 
the system interface unit module configuration register determines the type of parity, as 
described in Section 12.12.1.1 SIU Module Configuration Register. Any parity error 
causes the associated PER bit in the memory status register to be set. It also asserts the 
TEA signal and sets the corresponding DPB bit in the transfer error status register (TESR), 
which is described in Section 12.12.1.4 Transfer Error Status Register. The memory 
controller asserts an internal transfer error signal when a parity error occurs (if enabled). 
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15.3.1 Register Descriptions 


15.3.1.1 BASE REGISTERS. The base registers (BRO-7) contain the base address and 
address types that are used by the memory controller to compare the address bus with the 
current address accessed. It also includes a memory attribute and selects the machine for 
memory operation handling. After reset, BRO is referred to as the Boot BRO and it has a 
special functionality until the first write to ORO. 


BOOT BRO 


a ro 


(IMMR & OxFFFFO000) + 0x102 





This value depends on the value of the hard reset configuration word. 
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(IMMR & OxFFFF0000) + 0x102 (BRO), Ox10A (BR1), 0x112, (BR2), Ox11A (BR3), 0x122 (BR4), 0x12A (BR5), 0x132 (BR6), 0x13A (BR7) 





BA—Base Address 


This field, the upper 17 bits of each base address register, and the AT field are compared 
to the address on the address bus to determine if a memory bank controlled by the memory 
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-Memory Controller 


controller is being accessed by an internal bus master. These bits are used in conjunction 
with the AM field of the option register. 


AT—Address Type 


This field can be used to limit accesses to the memory bank to a certain address space type. 
These bits are used in conjunction with the ATM field of the option register. 


PS—Port Size 

This field specifies the port size of the memory region. After system reset, the value of this 
bit in BRO depends on the BPS field value in the hard reset configuration word. Refer to 
Section 4.3.1.1 Hard Reset ontiguraln Word for more information. | 


00 = 32- bit port size. 
01 = 8-bit port size. 
10 = 16-bit port size. 
11 = Reserved. 


PARE—Parity Enable 
This bit is used to enable parity checking on this bank. 
- Q= Parity checking is disabled. 
1 = Parity checking is enabled. © 


WP—Write-Protect 


This bit may. restrict write accesses within the address range of a base register. If you try to 
write to the range of addresses specified in a base address register that has this bit set, the 
bus monitor logic asserts the TEA signal which then terminates the cycle. 


0 = Both read and write accesses are allowed. 

1 = Only read accesses are allowed. The CSx and TA signals are not asserted by the 
memory controller on write cycles to this memory bank. The WPER bit is set in the 
MSTAT register if you try to write to this memory bank. 


MS—Machine Select 


_ This field specifies the machine that is selected for memory operations handling. 


~ 00 = GPCM. 
01 = Reserved. 
10 = UPMA. 
11 = UPMB. 
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Bits 26-30—Reserved 
These bits are reserved and should be set to 0. 


V—Valid 

This bit indicates that the contents of the base and option registers are valid. The CSx signal 
does not assert until this bit is set. An access to a region that does not have this bit set can 
cause a bus monitor timeout. After a system reset, the value of this bit in BRO depends on 
the BDIS bit value in the hard reset configuration word, which is described in 

Section 4.3.1.1 Hard Reset Configuration Word. | 


O = This bank is invalid. 
1 = This bank is valid. 


15.3.1.2 OPTION REGISTERS. The option registers (ORO-7) contain the address mask 
and address type mask bit for address bus comparison. It also includes the CS general field 
and all the GPCM parameters. After reset, ORO is referred to as the Boot ORO and it has a 
special functionality until the first write to ORO. 


BOOT ORO 





om : as 
(IMMR & OxFFFFO000) + 0x106 
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ORx 


(IMMR & OxFFFF0000) + 0x106 (ORO), 0x10E (OR1), 0x116 (OR2), Ox11E (OR3), 0x126 (OR4), 0x12E (ORS), 0x136 (OR6), Ox13E (OR7) 





NOTE: The reset value of ORO has predefined values as shown in the boot ORO register table. 


AM—Address Mask 


This read/write field provides masking on any corresponding bits in the associated base 
register. By masking the address bits independently, external devices of different size 
address ranges can be used. Any cleared bit masks the corresponding address bit and any 
set bit causes the corresponding address bit to be used in address pin comparison. The AM 
field can be set or cleared in any order in the field, thus allowing a resource to reside in more 
than one area of the address map. 


ATM—Address Type Mask 


This field masks certain bits in an aaarass type, thus allowing more than one address space 
type to be assigned to a chip-select. Any set bit causes the corresponding address type 
code bits to be used as part of the address comparison. Any cleared bit masks the 
corresponding address type code bit. The ATM field should be cleared so that address type 
codes are ignored as part of the address comparison. 


CSNT—Chip-Select Negation Time/SAM—Start Address Multiplex 


This bit is used for the GPCM and the SAM bit is used for the UPM. The CSNT bit, in 
conjunction with ACS and TRLX, is used to control negation of the CSx and WEx signals 
during an external memory write access handled by the general-purpose chip-select 
machine. This function provides extended address/data hold time for slower memories and 
peripherals. See Table 15-2 (page 15-29) for more information. 


The SAM bit determines the address output on the first cycle of an external memory access. 


0 = Address pins reflect the address requested by the internal master. 

1 = Address pins reflect the address requested by the internal master multiplexed 
according to the AMA field (if UPMA is selected to control the memory access) or 
the AMB field (if UPMB is selected). | 
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ACS—Address to Chip-Select Setup/G5LA 


This field is used for the GPCM and the G5LA and G5BLS fields are used for the UPM. This 
field controls CSx signal assertion in relation to address lines valid. 


00 = CS is output at the same time as the address lines. 

O1 = Reserved. | 

10 = CS is output a quarter of a clock later than the address lines. 
11 = CS is output half a clock later than the address lines. 


G5LS—General-Purpose Line 5A 


This field determines how the internal timing generator (GPL5) signal is output when the 
memory access is handled by the UPMA or UPMB. 


G5LA (only valid for UPMB): 
O = Output the internal GPL5 signal on the GPL_B5d pin. 
1 = Output the internal GPL5 signal on the GPL_A5 pin. 


G5LS (valid for UPMA or UPMB): 

O = The GPLD5 signal is driven low on the falling edge of GCLK1 during the first clock 
cycle of a read or write memory access. 

1 = The GPLS5 signal is driven high on the falling edge of GCLK1 during the first clock 
cycle of a read or write memory access. 








BlH—Burst Inhibit 


This bit determines whether or not this memory bank supports burst accesses. When a burst 
does not occur, the memory controller drives the BI signal active when accessing this - 
memory region. If the machine selected to handle this access is the GPCM, this bit should 
be set to 1. 


O= The Bl pin is negated. The bank supports burst accesses. 
1= The BI pin is asserted. The bank does not support burst accesses. 


SCY—Select Cycle Length (GPCM only) 

This field determines the number of wait states inserted in the cycle when the 
general-purpose chip-select machine handles the external memory access. It is one of the 
parameters that control the cycle’s length. The total cycle length is controlled by this 
parameter and the TRLX field. Refer to Table 15-2 (page 15-29) for the total number of 
cycles. | 
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_ Memory Controller 
If you want to use an external TA response (SETA bit = 1), then these bits are not used. 


0000 = O clock cycle wait state. 
0001 = 1 clock cycle wait state. 
0010 = 2 clock cycle wait states. 
0011 = 3 clock cycle wait states. 
0100 = 4 clock cycle wait states. 
0101 = 5 clock cycle wait states. 
0110 = 6 clock cycle wait states. 
0111 = 7 clock cycle wait states. 

- 1000 = 8 clock cycle wait states. 
1001 = 9 clock cycle wait states. 
1010 = 10 clock cycle wait states. 
1011 = 11 clock cycle wait states. 
1100 = 12 clock cycle wait states. 
1101 = 13 clock cycle wait states. 
1110 = 14 clock cycle wait states. 
1111 = 15 clock cycle wait states. 


SETA—Select External Transfer Acknowledge (GPCM only) 


_ This bit indicates when the TA signal is externally generated once the GPCM is selected to 
handle the memory access that was initiated to this memory region. Regardless of other 
setup parameters for the GPCM, if SETA = 1, then all control signals of the memory 
controller are negated after the externally generated TA signal is recognized. 


0 = Internal or external transfer acknowledge can acknowledge this memory access, 
whichever comes first. | 
1 = Transfer acknowledge must be provided by external logic. 


@ 


TRLX—Timing Relaxed (GPCM only) 

When this bit is set, it extends the timing of the signals controlling the memory devices once 
the GPCM is selected to handle the memory access that was initiated to this memory region. 
Refer to Table 15-2 (page 15-29) for more information. | 


0 = Timing is defined by the GPCM. 
~1= Relaxed timing is defined by the GPCM. 
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EHTR—Extended Hold Time on Read 


When this bit is set, it adds one clock cycle after a read from the current bank and any CPU 
write or read to a different bank. 


0 = Timing is defined by the memory controller. 
1 = Extended hold time is defined on the current read access. 


Bit 31—Reserved 
This bit is reserved and should be set to 0. 
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15.3.1.3 MEMORY STATUS REGISTER. The memory status (MSTAT) register reports 
parity and write-protect errors encountered during an external bus access initiated by the 
memory controller. To clear a specific bit, write a one to it (writing zero has no effect). 


MSTAT 


| PERO. PERi | PER2 | PER3 | PER4 | PERS | PER6 | PER7 | WPER RESERVED 


(IMMR & OxFFFFO000) + 0x178 





PERO—Parity Error Bank 0 


When this bit is set it indicates that a parity error was detected during a Bank 0 read cycle 
initiated by the memory controller. 


PER1—Parity Error Bank 1 


When this bit is set it indicates that a parity error was detected during a Bank 1 read cycle 
initiated by the memory controller. 


PER2—Parity Error Bank 2 


When this bit is set it indicates that a parity error was detected during a Bank 2 read cycle 
initiated by the memory controller. 


PER3—Parity Error Bank 3 


When this bit is set it indicates that a parity error was detected during a Bank 3 read cycle 
initiated by the memory controller. 


PER4—Parity Error Bank 4 


When this bit is set it indicates that a parity error was detected during a Bank 4 read cycle 
initiated by the memory controller. 
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PER5—Parity Error Bank 5 


When this bit is set it indicates that a parity error was detected during a Bank 5 read cycle 
initiated by the memory controller. 





PER6—Parity Error Bank 6 


When this bit is set it indicates that a parity error was detected during a Bank 6 read cycle 
initiated by the memory controller. 


PER7—Parity Error Bank 7 


When this bit is set it indicates that a parity error was detected during a Bank 7 read cycle 
initiated by the memory controller. 
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WPER—Write-Protection Error 


This bit is set when a write-protect error has occurred on a write cycle to a write-protected 
bank. The write-protect error is also stored in the transfer error status register of the system 
interface unit. See Section 12.12.1.4 Transfer Error Status Register for more information. 


lf the bus monitor is enabled, then TEA is asserted. The TEA signal will generate a machine 
check exception if it occurs between a TS and TA signal. When a TA is asserted before a 
write-protection error is detected, the TEA that occurs will not generate a machine check 
exception. Refer to Section 12.4 The Bus Monitor for more information. 


a7 4 Note: If the bus monitor is disabled and the write-protect error occurs, TEA assertion 
will not occur. See Section 12.12.1.4 Transfer Error Status Register for more 
information. 


Bits 9-4 5—Reserved 
These bits are reserved and should be set to 0. 
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15.3.1.4 MEMORY COMMAND REGISTER. The memory command register (MCR) 
allows you to issue commands to stimulate UPM routine execution. This capability enables 
the CPU to perform special memory operations in addition to the standard read/write and 
periodic timer service operations. 


MCR 


Er 


rs 
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Po | 
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(IMMR & OxFFFFO000) + 0x16A 


OP—Command Opcode 


This field defines the operation to be executed by the user-programmable machine that is 
specified in the UM field. 















00 = Writes the contents of the memory data register into the RAM location indexed by 
the MAD field. | 

01 = Reads the contents of the RAM location indexed by the MAD field and stores it in 
the memory data register. 

10 = Executes the RAM word in the RAM array that services one of the eight memory 
banks specified in the MB field. The executed RAM word is referenced by the 
MAD field. If the executed RAM word has the LAST bit set, it will be the last RAM 
word executed. 

11 = Reserved. 


a 
Lu 
—l 
—l 
2) 
o 
— 
_-< 
_ 2. 
© 
>. 
oa 
2) 
P= 
Lud 
= 





© 


Bits 2—7—Reserved 
These bits are reserved and should be set to O. 


UM—User Machine 
This bit selects the user-programmable machine for this command. 


O= UPMA. 
1 = UPMB. 


Bits 9—-15—Reserved 
These bits are reserved and should be set to O. 
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MB—Memory Bank 
This field selects the appropriate CSx pin when a RUN command is executed. 


000 = CSO is selected. 
001 = CS71 is selected. 
010 = CS2 is selected. 
011 = CS3 is selected. 
100 = CS4 is selected. 
101 = CS5 is selected. 
110 = CS6 is selected. 
111 = CS7 is selected. 


Bits 19 and 24~25—Reserved 
_ These bits are reserved and should be set to 0. 


MCLF—Memory Command Loop Field 
This field specifies the number of times a loop is executed for any command. 


0001 = The loop is executed 1 time. 
0010 = The loop is executed 2 times. 
0011 = The loop is executed 3 times. 
0100 = The loop is executed 4 times. 
0101 = The loop is executed 5 times. 
0110 = The loop is executed 6 times. 
0111 = The loop is executed 7 times. 
1000 = The loop is executed 8 times. 
1001 = The loop is executed 9 times. 
1010 = The loop is executed 10 times. 
1011 = The loop is executed 11 times. 
1100 = The loop is executed 12 times. 
1101 = The loop is executed 13 times. 
1110 = The loop is executed 14 times. 
1111 = The loop is executed 15 times. © 
0000 = The loop is executed 16 times. 
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MAD—Memory Array Index 


This field specifies an index to one of 64 RAM words in the RAM array for command 
execution. 
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15.3.1.5 MACHINE A MODE REGISTER. The machine A mode register (MAMR) contains 


the configuration for the user-programmable machine A. See Figure 15-1 (page 15-3) for 
more information. 


MAMR 





(IMMR & OxFFFFO000) + 0x172 


PTA—Periodic Timer A Period 


This field affects the periodic timer A and determines the timer period service rate according 
to the following equation: 


System Clock (MHz) x Service Duration (us) 


PTA = 
2? xDFeRrs x Prescaler (PTP) x NCS 


NCS is an integer between 1 and 8 that represents the number of enabled chip-selects that 
select this UPM. The DFBRG field is the division factor for the BRGCLK, which can be divide 
by 1 (default), 4, 16, or 64 and is programmed in the system clock and reset control register 
(SCCR) in Section 5.2 Register Model. 


For example, for DRAM to maintain data integrity an access or refresh must occur every 
15.6us. Use the equation above to determine the PTA value for UPMA to perform memory 
refresh. Given that you have a 25MHz system clock with the required service rate of 15.6us, 
a periodic timer prescaler equal to 32, and a DFBRG field that is equal to 0, then the PTA 
value should be (25 x 15.6) / (2° x 32x 1) = 12. If you want to perform more than one refresh 
per service, use the TFLA field. 


PTAE—Periodic Timer A Enable 
This bit allows the periodic timer A to request service. 


O= Periodic timer A is disabled. 
1 = Periodic timer A is enabled. 
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Memory Controller | 


AMA—Address Multiplex Size A 


This field specifies the number of address lines to be suiputs on the bus at the first clock of 
the memory cycle. Refer to Table 15-7 (page 15-60) for more information. The AMX field of 
the RAM array entry controls the output of the address lines. Refer to Table 15-3 

(page 15-38) for more information. For example, these address lines can be used to connect 
to the DRAM devices that require row and columns to be See on the same pin. 


Bits 12 and 15—Reserved | 
These bits are reserved and should be set to 0. 


DSA—Disable Timer Period 


This bit guarantees a minimum time senieeh accesses to the same memory bank if itis. 


controlled by the UPMA. The TODT bit turns on the disable timer in the RAM array and, 
when expired, the UPMA allows the machine access to issue a memory pattern to the same 
memory region. Accesses to different memory regions using two or more chip-selects can 
be handled by this same UPMA, assuming they have the same timing. The maximum 
disable period is four clock cycles. When switching to a different bank that requires more 
than four clock cycles, you must add more UPM RAM word to meet your time requirement. 


_ Refer to Section 15.5.4.2 RAM Word Operation for more specific DRAM example 


information. 


00 = 1-cycle disable period. 
01 = 2-cycle disable period. 
10 = 3-cycle disable period. 
11 = 4-cycle disable period. 


GOCLA—General Line 0 Control A 


This field selects the address line that is output to the internal GPLO signal when the UPMA 
is selected to control memory access. | 


000 = A12. 
001 = Alt. 
010 = A10. 
011 = AQ. 
100 = A8. 
101 = AZ. 
110 = AG. 
111= A5. 


GPLA4DIS—GPLA4 Output Line Disable 


This bit determines whether or not the UPWAITA/GPL_A4 pin will behave as an output line 
controlled by the internal GPL4 signal and the UPM RAM word. 





0 = UPWAITA/GPL_A4 is defined as GPL_A4.  _ 
1 = UPWAITA/GPL_A4 is defined as UPWAITA. 
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RLFA—Read Loop Field A 


This field specifies the number of times a loop defined in the UPMA RAM word is executed 
for a burst read or single beat read cycle. 


0001 = The loop is executed 1 time. 
0010 = The loop is executed 2 times. 
0011 = The loop is executed 3 times. 
0100 = The loop is executed 4 times. 
0101 = The loop is executed 5 times. 
0110 = The loop is executed 6 times. 
0111 = The loop is executed 7 times. 
1000 = The loop is executed 8 times. 
1001 = The loop is executed 9 times. 
1010 = The loop is executed 10 times. 
1011 = The loop is executed 11 times. 
1100 = The loop is executed 12 times. 
1101 = The loop is executed 13 times. 
1110 = The loop is executed 14 times. 
1111 = The loop is executed 15 times. 
0000 = The loop is executed 16 times. 


WLFA—Write Loop Field A 


This field specifies the number of times a loop defined in the UPMA RAM word is executed 
for a burst write or a single beat write cycle. 


0001 = The loop is executed 1 time. 
0010 = The loop is executed 2 times. 
0011 = The loop is executed 3 times. 
0100 = The loop is executed 4 times. 
0101 = The loop is executed 5 times. 
0110 = The loop is executed 6 times. 
0111 = The loop is executed 7 times. 
1000 = The loop is executed 8 times. 
1001 = The loop is executed 9 times. 
1010 = The loop is executed 10 times. 
1011 = The loop is executed 11 times. 
1100 = The loop is executed 12 times. 
1101 = The loop is executed 13 times. 
1110 = The loop is executed 14 times. 

1111 = The loop is executed 15 times. 

0000 = The loop is executed 16 times. 
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TLFA—Timer Loop Field A 


This field specifies the number of times a loop defined in the UPMA RAM word is executed 
for a periodic timer service. , 


0001 = The loop is executed 1 time. 
0010 = The loop is executed 2 times. 
0011 = The loop is executed 3 times. 
0100 = The loop is executed 4 times. 
0101 = The loop is executed 5 times. 
0110 = The loop is executed 6 times. 
0111 = The loop is executed 7 times. 
1000 = The loop is executed 8 times. 
1001 = The loop is executed 9 times. 
1010 = The loop is executed 10 times. 
1011 = The loop is executed 11 times. 
1100 = The loop is executed 12 times. 
1101 = The loop is executed 13 times. 
1110 = The loop is executed 14 times. 
1111 = The loop is executed 15 times. 
0000 = The loop is executed 16 times. 
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15.3.1.6 MACHINE B MODE REGISTER. The machine B mode register (MBMR) contains 


the configuration for the user-programmable B machine. see Figure 15-1 (page 15-3) for 
more information. 


MBMR 





(IMMR & OxFFFFO000) + 0x176 


PTB—Periodic Timer B 


This field affects the periodic timer B and determines the timer period according to the 
following equation: 


System Clock (MHz) x Service Duration (us) 


PTB = 
2? xDFERS y Prescaler (PTP) x NCS 


NCS is an integer between 1 and 8 that represents the number of enabled chip-selects that 
select this UPM. The DFBRG field is the division factor for the BRGCLK, which can be divide 
by 1 (default), 4, 16, or 64 and is programmed in the system clock and reset control register 
(SCCR) in Section 5.2 Register Model. 
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For example, for DRAM to maintain data integrity an access or refresh must occur every 
15.6us. Use the equation above to determine the PTB value for UPMB to perform memory 
refresh. Given that you have a 25MHz system clock with the required service rate of 15.6us, 
a periodic timer prescaler equal to 32, and a DFBRG field that is equal to 0, then the PTB 
value should be (25 x 15.6) / (22*° x 32x 1) = 12. If you want to perform more than one refresh 
per service, use the TFLB field. 





PTBE—Periodic Timer B Enable 
This bit allows the periodic timer B to request service. 


O= Periodic timer B is disabled. 
1 = Periodic timer B is enabled. 
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~ AMB—Address Multiplex Size B 


This field specifies the number of address lines to be output on the bus at the first lock of 
the memory cycle. Refer to Table 15-7 (page 15-60) for more information. The AMX field of 
the RAM array entry controls the output of the address lines, as shown in Table 15-3 
(page 15-38). For example, these address lines can be used to connect to the DRAM 


devices that require row and columns to be multiplexed on the same pin. 


Bits 12 and 15—Reserved 
These bits are reserved and should be set to 0. 


DSB—Disable Timer Period 


This bit guarantees a minimum time between accesses to the same memory bank if it is” 
controlled by the UPMB. The TODT bit turns on the disable timer in the RAM array and, 
when expired, the UPMB allows the machine access to issue a memory pattern to the same 
memory region. Accesses to different memory regions using two or more chip-selects can 
be handled by this same UPMB, assuming they have the same timing. The maximum 
disable period ts four clock cycles. When switching to a different bank that requires more 
than four clock cycles, you must add more UPM RAM word to meet your time requirement. 
Refer to Section 15.5.4.2 RAM Word Operation for more specific DRAM example 
information. — | 


OO = 1-cycle disable period. 
01 = 2-cycle disable period. 
10 = 3-cycle disable period. 
11 = 4-cycle disable period. 


GOCLB—General Line 0 Control B 


This field selects the address line that is output to the internal GPLO signal when the UPMB 
is selected to control memory access. 


000 = A12. 
001 = A11. 
010 = A10. 
011 = AQ. 
100 = A8. 
101 = AZ. 
110 = AG. 
111 = AS. 


GPLB4DIS—GPLB4 Output Line Disable 


This bit determines whether or not the UPWAITB/GPL_B4 pin will behave as an output line 
controlled by the internal GPL4 signal and the UPM RAM word. 





0 = UPWAITB/GPL_B4 is defined as GPL_B4. 
1 = UPWAITB/GPL_B4 is defined as UPWAITB. 


15-24 ~ MPC823 USER’S MANUAL MOTOROLA 


Memory Controller 


RLFB—Read Loop Field B 


This field specifies the number of times a loop defined in the UPMB RAM word is executed 
for a burst read or single beat read cycle. 


0001 = The loop is executed 1 time. 
0010 = The loop is executed 2 times. 
0011 = The loop is executed 3 times. 
0100 = The loop is executed 4 times. 
0101 = The loop is executed 5 times. 
0110 = The loop is executed 6 times. 
0111 = The loop is executed 7 times. 
1000 = The loop is executed 8 times. 
1001 = The loop is executed 9 times. 
1010 = The loop is executed 10 times. 
1011 = The loop is executed 11 times. 
1100 = The loop is executed 12 times. 
1101 = The loop is executed 13 times. 
1110 = The loop is executed 14 times. 
1111 = The loop is executed 15 times. 
0000 = The loop is executed 16 times. 


WLFB—Write Loop Field B 


This field specifies the number of times a loop defined in the UPMB RAM word is executed 
for a burst write or a single beat write cycle. 


0001 = The loop is executed 1 time. 
0010 = The loop is executed 2 times. 
0011 = The loop is executed 3 times. 
0100 = The loop is executed 4 times. 
0101 = The loop is executed 5 times. 
0110 = The loop is executed 6 times. 
0111 = The loop is executed 7 times. 
1000 = The loop is executed 8 times. 
1001 = The loop is executed 9 times. 
1010 = The loop is executed 10 times. 
1011 = The loop is executed 11 times. 
1100 = The loop is executed 12 times. 
1101 = The loop is executed 13 times. 
1110 = The loop is executed 14 times. 
1111 = The loop is executed 15 times. 
0000 = The loop is executed 16 times. 
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TLFB—Timer Loop Field B 


This field specifies the number of times a loop defined in the UPMB RAM word is executed 
for a periodic timer service cycle. 


0001 = The loop is executed 1 time. 

0010 = The loop is executed 2 times. 

0011 = The loop is executed 3 times. 

0100 = The loop is executed 4 times. | say. 2 a: a 
0101 = The loop is executed 5 times. 7 ma | se 
0110 = The loop is executed 6 times. 

0111 = The loop is executed 7 times. 

1000 = The loop is executed 8 times. | 
1001 = The loop is executed 9 times. ae | . a! 
1010 = The loop is executed 10 times. 

1011 = The loop is executed 11 times. 

1100 = The loop is executed 12 times. 

1101 = The loop is executed 13 times. 

1110 = The loop is executed 14 times. 

1111 = The loop is executed 15 times. | 

0000 = The loop is executed 16 times. 


15.3.1.7 MEMORY DATA REGISTER. The memory data register (MDR) contains the data 
to be written to or read from the RAM array for UPM command operations. This register must 
be set up before you issue a write command to the memory command register. | 


MDR 
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(IMMR & OxFFFFO000) + 0x17E 





MD—Memory Data 
This field contains the RAM array word. 
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15.3.1.8 MEMORY ADDRESS REGISTER. The memory address register (MAR) contains 
an address to be output on the address lines that are controlled by me AMX field in the RAM 
word of the RAM array. 


MAR 





(IMMR & OxFFFFO000) + 0x166 


MA—Memory Address 


This field contains a 32-bit address to be output on the address bus if the AMX field is equal 
to 11. Refer to Section 15.5.4 The RAM Array for more information. 
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15.3.1.9 MEMORY PERIODIC TIMER PRESCALER REGISTER. The memory periodic 
timer prescaler register (MPTPR) defines the divisor of the BRGCLK used as the memory 
periodic timer input clock. Refer to Section 5.3.4 Internal Clock Signals for details. 


MPTPR 











a "RESERVED 
| 00000001 00000000 
(IMMR & OxFFFF0000) + 0x17A 


PTP—Periodic Timers Prescaler 
This field determines the division factor that is shown below. 


0OO1x xxxx = _ Divide by 2. 
0001 xxxx = Divide by 4. 
OOOO 1xxx = Divide by 8. 


0000 01xx = Divide by 16. 
0000 001x = Divide by 32. 
0000 0001 = Divide by 64. 
1XxXX XxXxX = Reserved. - 
O1xx xxxx = Reserved. 


Bits 8—15—Reserved 
These bits are reserved and should be set to 0. 


15.4 THE GENERAL-PURPOSE CHIP-SELECT MACHINE 


The general-purpose chip-select machine (GPCM) allows a glueless and flexible interface 
between the MPC823, SRAM, EPROM, FEPROM, ROM devices, and external peripherals. 
The GPCM contains three basic register groups that you can use to configure it—base 
registers O—7, option registers O—7, and the memory status register. 


15.4.1 Configuration 


If the MS field in the BRx of the selected bank selects the general-purpose chip-select 
machine, the attributes for the memory cycle initiated are taken from the ORx. These 
attributes include the CSNT, ACS, SCY, TRLX, EHTR, and SETA fields. See Table 15-2 for 
signal behavior and system response. 
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Anywhere from 0 to 30 wait states can be programmed for TA generation. The WEx signals 
are available for each byte that is written to memory. Also, an OE signal is provided to 


eliminate external glue logic. On system reset, a global chip-select (CSO) is asserted to 
provide a boot ROM chip-select before the system is fully configured. 


Table 15-2. GPCM Strobe Signal Behavior 


OPTION REGISTER SIGNAL BEHAVIOR 
ATTRIBUTES 


ADDRESS ADDRESS | ADDRESS csx TOTAL 
TRLX | ACCESS CSNT 
TYPE 























TO CSx TO OE TO WEx 
ASSERTED | ASSERTED | ASSERTED ASSERTED TO 
ADD/DATA 

INVALID 


1/4*Clock 3/4*Clock 
rae 1/2*Clock 
po | 8 18" Cock 


1/4*Clock 1/4*Clock 

1/2*Clock peed 

Ok 3/4*Clock | -1/4*Clock 1/2*Clock 
peo 

1/2*Clock 

1 

po foo | 1arCiock | 

1/4*Clock 3/8* Clock 
j awom 

| 11 | WetClock 1/2*Clock 







OF 
CYCLES 





ADD/DATA 
INVALID 





zc. a ae 3/4*Clock | as2tscy | 
(1+1/4)*Clock | 1+3/4*Clock 
3+2*SCY 

(1+1/2)*Clock | 1+3/4*Clock 
foo fo | 3/4°Clock | } -1/4*Clock | 1/4*Clock | 2s2rscy | 
| 10 | (1+1/4)*Clock 1+3/4*Clock ]| 3/4*Clock 1/4*Clock 
Pae (1+1/2)*Clock 1+3/4*Clock | 3/4*Clock 3+2°SCY 
Fo fo aarciock | acieck | 
(1+1/4)*Clock 143/4*Clock } 3/4%Clock | 1+1/2*Clock 

14+1/2*Clock 4+2*SCY 
(1+1/2)*Clock 14+3/4*Clock | 3/4*Clock 
} oo | oo 3/4*Clock | -1/4*Clock | 1/4*Clock 34+2*SCY 
OP 3/8*Clock 


4+2*°SCY 







(1+1/4)*Clock 1+3/4*Clock | 3/4*Clock 
| wom 
(1+1/2)*Clock 


NOTE: SCY is the number of wait cycles from the option register. 





1+3/4*Clock 3/4*Clock 
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Memory Controller 


Next, the banks selected by the general-purpose chip-select machine support an option to 


output the CSx signal at different timings with respect to the external aadiess bus. CSx can 
be output in any of the following configurations: : 


e Simultaneous with the external address 
e One quarter of a clock later 
e One half of a clock later 


This all depends, of course, on the value of the ACS field, plus an additional cycle if the 
TRLX bit is set. The general-purpose chip-select machine allows you to connect to devices 
that have long disconnect times on data by delaying new bus transactions addressing other 
memory banks for additional clock cycles. Finally, the banks selected to operate with the 
general-purpose chip-select machine support termination of an external cycle by sensing 
the TA signal asserted by the addressed external slave. Refer to Table 15- 2 formore — 
information. 


MPC823 | ~ - MEMORY 





Figure 15-5. GPCM Memory Device Interface 


Figure 15-5 illustrates a basic connection between the MPC823 3 anda “static” memory 
device. In this case, the CSx signal is connected directly to the CE signal of the memory 
device. The WEx signals are connected to the respective W signal in the memory device 


_ where each WEx signal Eres eNS: toa different data byte. 
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As illustrated in Figure 15-6, the timing of the CSx signal is the same as the timing of the 
address lines. The strobes for the transaction are supplied by the OE or WEx signals, 
depending on the transaction direction (read or write). The negation of the WEx signal is 


controlled by the CSNT bit. The CSx signal is generated when the ACS field in the 
corresponding ORx register is set to ‘00’. 


CLOCK | | | 


| 
TS R * | | | 
| | 
es aaa a | / 
TA | | | CSNT = 1 
| | 
\ | | / 


GS | 
| 
_ | 
WE | | 
| | 
SE | | | 
| | 
| | 
DATA | | 


Figure 15-6. GPCM Memory Device Basic Timing 
(ACS = 00, CSNT = 1, and TRLX = 0) 


o 
Lu 
—! 
— 
eo) 
oc 
= 
<— 
Oo 
oO 
> 
oc 
Oo 
= 
Lu 
= 





MOTOROLA MPC823 USER’S MANUAL 15-31 


Memory Controller 


Figure 15-7 illustrates the basic connection between the MPC823 and an external 
peripheral device. In this case, CSx is connected directly to the CE signal of the memory 
device and the R/W signal is connected to the respective R/W signal in the peripheral 
device. The CSx signal is the strobe output for the memory access. 


MPC823 PERIPHERAL 


ADDRESS 





Figure 15-7. GPCM Peripheral Device Interface 


Figure 15-8 illustrates the CSx signal as defined by the setup time required between the 
address lines and the CE signal. The MPC823 memory controller allows you to specify the 
CSx signal to meet this requirement using the ACS field in the option register. 


CLOCK | 7 | 


| ACS = 10 
TS 3 | 
| 
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DATA 





Figure 15-8. GPCM Peripheral Device Basic Timing (ACS = 10 or 11 and TRLX = 0) 
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The general-purpose chip-select machine also provides a CSNT attribute in the option 

~ register that controls the timing for the appropriate strobe negation in write cycles. When this 
attribute is asserted, the strobe is negated one quarter of a clock before the normal case. 
For example, when the ACS field equals 00 and CSNT is set, WEx is negated one quarter 
of a clock earlier and when ACS does not equal 00 and CSNT is set, WEx and CSx are 
negated one quarter of a clock earlier. For more information, see Figure 15-6, Figure 15-8, 
and Table 15-2. 


The TRLX field in the option register is provided for memory systems that require more 
relaxed timing between signals. When TRLX is set and the ACS field is not equal to 00, an 
additional cycle between the address and strobes is inserted by the MPC823 memory 
controller, as shown in Figure 15-9. 


When TRLX and CSNT are set in a write-memory access, the strobe lines (WEx and CSx, 
if ACS is not equal to 00) are negated one clock earlier than in the normal case, as shown 
in Figure 15-11. When a bank is selected to operate with external transfer acknowledge 
(SETA and TRLX are set), the memory controller does not support external devices that 
provide the TA signal to complete the transfer with zero wait states. The minimum access 
duration in this case is three clock cycles. 


CLOCK 


ADDRESS 





Figure 15-9. MPC823 GPCM-Relaxed Timing—Read Access 
(ACS = 10 or 11, SCY = 1, and TRLX =1) 
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15-34 


| | 
ADDRESS | | 





| l 


Figure 15-10. MPC823 GPCM-Relaxed Timing—Write Access 
(ACS = 10 or 11, SCY = 0, CSNT = 0, and TRLX =1) 


CLOCK 


ADDRESS 





Figure 15-11. MPC823 GPCM-Relaxed Timing—Write Access 
(ACS = 10 or 11, SCY = 0, CSNT = 1, and TRLX =1) 
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CLOCK | | | | | | 


| | | 
| | | 
DATA | | | 
| ! 


Figure 15-12. MPC823 GPCM-—Relaxed Timing—Write Access 
(ACS = 00, SCY = 0, CSNT = 1, and TRLX =1) 


15.4.1.1 PROGRAMMABLE WAIT STATE CONFIGURATION. The general-purpose 
chip-select machine supports internal TA signal generation. It allows “fast” accesses to 
external memory through an internal bus master or it allows a maximum 17-clock access. 
This can be done by programming the SCY field in the option register. The internal TA 
generation mode is enabled if the SETA field in the option register is cleared. If the TA pin 
is externally asserted at least two clock cycles before the wait state counter has expired, the 
current memory cycle is terminated. When the TRLX bit is set, the number of wait states 
inserted by the memory controller is defined by 2 x SCY or a maximum of 30 wait states. 
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15.4.1.2 EXTENDED HOLD TIME ON READ ACCESSES. Slow memory devices that 
require a long delay on data read accesses should set the EHTR field in the corresponding 
option register. Any GPCM access to the external bus following a read access to the slower 
memory bank is delayed by one clock cycle, unless it is a read access to the same bank. 
Refer to Figure 15-13 through Figure 15-16 for details. 
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Figure 15-14. GPCM Write Followed By Read (EHTR = 1) 
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CLOCK 
bee ee 






LONG HOLD TIME ALLOWED 
| | 


| | | 
| | | 
| | | 
| | | 
| | | 
I I | 


Figure 15-15. GPCM Read Followed By Read From Different Banks (EHTR = 1) 
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Figure 15-16. GPCM Read Followed By Read From Same Bank (EHTR = 1) 
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15.4.1.3 BOOT CHIP-SELECT OPERATION. Boot chip-select operation allows address 
decoding for a boot ROM before system initialization occurs. The CSO signal is the boot 
chip-select output-and its operation differs from the other external chip-select outputs on 
system reset. When the MPC823 internal core begins accessing memory at system reset, 
CS0 is asserted for every address, unless an internal register is accessed. 


The boot chip-select provides a programmable port size during system reset by using the 
BPS field of the hard reset configuration word, as shown in Section 4.3.1.1 Hard Reset 
Configuration Word. Setting these appropriately allows a boot ROM to be located 
anywhere in the address space. The boot chip-select does not provide write protection and 
responds to all address types. CSO operates this way until the first write to the option register 
0 and it can be used as any other chip-select register once the preferred address range is 
loaded into base register O. After the first write to option register 0, the boot chip-select can 
only be restarted on system reset. The initial values of the “boot bank” in the memory 
controller are described in Table 15-3. 


Table 15-3. Boot Bank Field Values After Reset 


FIELD VALUE 
From Hard Reset Configuration Word 












Base Register 0 







Option Register 0 
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15.4.1.4 SRAM INTERFACE. Figure 15-17 illustrates a simple connection between an 
SRAM device and the MPC823. 


MPC823 32-BIT WIDE SRAM 


GPL_x1/0OE 


A(15:29] 


D(0:31] 





Figure 15-17. GPCM to SRAM Configuration 


15.4.1.5 EXTERNAL ASYNCHRONOUS MASTER SUPPORT. Figure 15-18 illustrates 
the basic interface between an asynchronous external master and the GPCM to allow 
connection to “static RAM” memory. 


ASYNCHRONOUS EXTERNAL MASTER 
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Figure 15-18. Asynchronous External Master Configuration For 
GPCM-Handled Memory Devices 
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Figure 15-19 illustrates the timing for TRLX = 0 when an external asynchronous master _ 
accesses SRAM. The TA signal remains asserted with the WE and OE signals until the AS 
signal is negated by the external master. 


CLOCK | | | | | | | 


ADDRESS 


DATA 


Vi 


Figure 15-19. Asynchronous External Master, GPCM-Handled 
Memory Access Timing (TRLX = 0) 


When an external asynchronous master performs an access to a memory device via the 
general-purpose chip-select machine in the mens ees the CSNT bit in the option 
register is configured as “don’t care”. 
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15.5 USER-PROGRAMMABLE MACHINES 


Each of the two user-programmable machines (UPMs) isa flexible interface that connects 
to a wide range of memory devices. At the heart of each UPM is an internal memory RAM 
array that specifies what the logical value driven on the external memory controller pins are 
for a given clock cycle. Each word in the RAM array provides bits that allow a memory 
access to be controlled with a resolution of one quarter of the system clock period on the 
byte-select and chip-select lines. Figure 15-20 illustrates the basic operation of each UPM. 
The following basic methods can be used to initiate a UPM cycle: 


e Any internal or external master requests an external memory access 

e A memory periodic timer expires and requests a transaction 

e A transfer error or reset generates an exception request 

e The memory command register receives a RUN command (software) from the CPU 


INTERNAL/EXTERNAL MEMORY 




















ACCESS REQUEST 
MEMORY PERIODIC TIMER 
INDEX in 
SOFTWARE REQUEST ee enean ARRAY 
EXCEPTION REQUEST 
Z 
a 
aa | 
(@) 
cr 
-~ 
g 
INCREMENT on 
HOLD > 
INDEX INTERNAL & 
(LAST = 0) SNA SIGNALS 3 
TIMING GENERATOR a 
LATCH | 
WAIT 


UPWAIT REQUEST 
| WAEN BIT 





LOGIC 





INTERNAL CONTROLS | 


Figure 15-20. User-Programmable Machine Block Diagram 


The RAM array contains 32-bit entries referred to as RAM words. If the UPM reads a RAM 
word with the WAEN bit set, the external UPWAITx signal is sampled and synchronized by 
the memory controller and the current request is frozen. The signal timing generator will load 
the RAM word from the RAM array to drive the general-purpose lines, byte-selects, and 
chip-selects. | 
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15.5.1 Requests 
_ The user-programmable machine has four basic requests that can initiate a UPM cycle. 
There is a special start address in the RAM array that is associated with each of the following 
-cycletypes: | 7 
° Read single beat start address (RSS) 
e Read burst cycle start address (RBS) 
e Write single beat start address (WSS) 
e Write burst cycle start address (WBS) 
e Periodic timer start address (PTS) 
e Exception condition start address (EXS) 


Figure 15-21 illustrates the first locations addressed by the UPM, according to the different 
cycle types. Software requests, however, can point to any of the 64 UPM RAM entries. 


READ SINGLE BEAT REQUEST RSS 
BURST READ REQUEST 
ARRAY 
INDEX 
GENERATOR 
a WRITE SINGLE BEAT REQUEST = wss 
| @ RAM ARRAY aH 
© é 
oe] 
me 
OQ 
(ole 
= 
iS) PERIODIC TIMER REQUEST 
in : ; 
a 
EXS 





EXCEPTION CONDITION 


Figure 15-21. RAM Array Indexing 
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15.5.1.1 INTERNAL/EXTERNAL MEMORY ACCESS REQUESTS. When any of the 
internal masters request a new access to external memory, the address and type of the 
transfer are compared to each one of the valid banks defined in the base register. The value 
of the MS field in the base register selects the UPM that will handle the memory access. You 
must ensure that the appropriate UPM entries are created prior to your request. 


The external memory access requests consist of read single beat, read burst, write single 
beat, and write burst. A single beat cycle is generated by the master to a cache-inhibited 
memory bank. A typical burst cycle is generated to the memory that allows multiple 
accesses. It only occurs when your memory is burstable. A single beat cycle starts out with 
one transfer start and ends with one transfer acknowledge. For a 32-bit access, the burst 
cycle starts out with one transfer start but ends with four transfer acknowledges. For a 16-bit 
bus, there are eight transfer acknowledges. For an 8-bit bus, there are 16 transfer 
acknowledges. 


15.5.1.2 MEMORY PERIODIC TIMER REQUESTS. Each UPM contains a periodic timer 
that can be programmed to generate periodic service requests that will be indexed into the 
RAM array. Figure 15-22 illustrates the hardware associated with memory periodic timer 
request generation. In general, the periodic timer is used for refresh cycle operation. 


SYSTEM __y.|BRG PRESCALER|__y> 
CLOCK (IN THE SCCR) 






> UPMA PERIODIC 


PERIODIC 
TIMER REQUEST 


TIMER A 
(PTA) 













MEMORY 
PERIODIC. 
TIMER 
PRESCALER 
(IN THE MPTPR) 












UPMB PERIODIC 
TIMER REQUEST 


PERIODIC LL. 
TIMER B 
(PTB) 







Figure 15-22. Memory Periodic Timer Request Block Diagram — 


15.5.1.3 SOFTWARE REQUESTS. The software can initiate a request to the 
user-programmable machine by issuing one of three commands—read, write, or execute a 
RAM word— to the memory command register. Every memory device has its own signal 
handshaking protocol to put it into self-refresh mode or any special protocol mode. In the 
user-programmable machine there are unused areas that enable you to write a special RAM 
word for this protocol. Any unused area in the UPM RAM can be used to store these RAM 
words. Typically, software requests are used to put the memory in self-refresh mode. You 
can use this method to maintain memory integrity before going into low-power or lower 
power modes. A new command must be issued to exit self-refresh mode or any special 
protocol mode after returning to normal operation. 
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15.5.1.4 EXCEPTION REQUESTS. When an access to a memory device is initiated by the 
MPC823 under UPM control, the external device may assert the TEA, SRESET, or HRESET 


_ signal. The UPM provides a mechanism that allows you to handle the memory control 
- Signals to meet the timing requirements of the device and assume no data is lost. 


15.5.2 Programming the User-Programmable Machine 


The user-programmable machine is a micro-sequencer that requires micro-instructions or 
RAM words to generate signal timings for different memory cycles. You should program the 
user-programmable machine in the following order: | 


Write a program into the RAM array. 
Set up the base and option registers. 


Program the memory periodic timer prescaler register. 
Program the machine mode register. 


Sy IN 


Each user-programmable machine has a machine mode register (MxMR) that defines the 
general attributes for operation. The PTA field of the MAMR and the PTB field of the MBMR 
defines the period for the timers associated with UPMA and UPMB. If the PTAE bit is set, 
the periodic timer of UPMA requests a transaction when the timer period expires. If the 
PTBE bit is set, the periodic timer of UPMB requests a transaction when the timer period 
expires. 


To initiate a software request, issue the appropriate command to the memory command 
register with the MAD field indexing the first entry of the UPM entry word. Command 
execution is accomplished by accessing consecutive RAM words (one per clock) until the 
word with the LAST bit set is encountered. The words read from the RAM provide 
information about the value and timing of the external signals controlled by the UPM and 
about specific strobes that control internal memory controller resources. 


There is a disable timer mechanism associated with each user-programmable machine that 
is only active between memory accesses. This timer is used to provide a delay between 
successive memory cycles to the same bank. 


Each of the UPMs can control how the address of the current access is output to the external 
pins. Address multiplexing configurations for a specific memory or device can be selected 
in the machine mode register. There is also a multiplexing field in the RAM word that is used 


to control cycle-by-cycle accesses. Specific user-programmable machine register 
_ information is located in Section 15.3.1 Register Descriptions. 
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15.5.3 Clock Timing 


The RAM word includes fields that specify the value of the various external signals at each 
clock edge. The signal timing generator causes the external signals to behave according to 
the timing specified in the current RAM word. Figure 15-23 and Figure 15-24 illustrate the 
clock schemes of the user-programmable machines in the memory controller. The clock 
phases shown in these figures reflect timing windows that specify when generated signals 
can change state. Figure 15-23 represents the clock scheme selected when the EBDF field 
of the system clock and reset control register (SCCR) is equal to 00. As indicated in the 
figure, CLKOUT is the same as system clock. In Figure 15-24, if the EBDF field of the 
system clock and reset control register is equal to 01, then CLKOUT is equal to the system 
clock divided by 2. Notice that in this scheme GCLK1 does not have a 50% duty cycle. The 
state of the external signals may change (if specified in the RAM array) at any edge of 
GCLK1 and GCLK2, plus a propagation delay. 


SYSTEM CLOCK | | | | | | 
CLKOUT | | | | | 


GCLK1 | | | | 


GCLK2 | | | : 
| 


CLOCK PHASE © i, oh je eh Be Ae ea ee eg 
. : 


| 
GCLK2 | | ) | | | | | | 
| | | | | | | 
CLOCK PHASE 4 i eS a a ae Ge 
| | | | | | 


Figure 15-24. UPM Clock Scheme Two (Division Factor = 2 
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The CSx signals are handled in a similar way, except that only the CSx signal corresponding 
to the currently accessed bank is modified. The BS signal assertion and negation timing is 
also specified for each cycle in the RAM word, but the final value of each one of these 
signals depends on the port size of the specified bank, the external address accessed, and 
‘the value of the TSIZx pins. 


Figure 15-25 and Figure 15-26 provide examples of how to control the timing of the CSx, 
-GPL1, and GPL2 signals A RAM word is read on the rising edge of every GCLK2 cycle or 
in phase 3 of the previous clock cycle. It determines the value of the CST1-4, G1T3, G1T4, 
G2T3, and G2T4 bits, which specifies the timing of chip-selects, byte-selects, and GPLx 
signals based on any edge of GCLK1 or GCLK2. The clock phases shown in these figures 
refer to the timing windows when the signals controlled by these bits in the RAM wore: are 
driven. — 
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SYSTEM CLOCK | 
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CLKOUT | | . | | | | 
| | | 


GCLK1 | | | | | | 
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Figure 15-25. UPM Signals Timing Example One 
(Division Factor = 1, EBDF=00) | 


15-46 MPC823 USER’S MANUAL ~ MOTOROLA 


Memory Controller 


SYSTEM CLOCK | | | | | | | | | | | oe 
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RAM WORD 1 RAM WORD 2 


Figure 15-26. UPM Signals Timing Example Two 
(Division Factor = 2, EBDF = 01) 
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15.5.4 The RAM Array 


The RAM array size for each UPM is 64 locations deep and 32 bits wide as illustrated in 
Figure 15-27. The selected bank is one of eight banks that matches the current address. 
The signal generation shown at the bottom part of the figure are outputs of the UPM and not 
direct signal outputs of the MPC823. 


32 BITS WIDE 


RAM ARRAY 64 
RAM 
WORDS 
DEEP 





GCLK1 3 : 
GCLK2 SIGNALS TIMING GENERATOR 


q 
< 
oO 
< 


SELECTED BANK BS SIGNAL TSIZx, PS, A[30,31] 


CS SIGNA 
een SELECTOR 


SELECTOR 





CSx GPLO GPLi GPL2 GPL3 GPL4 GPL5 BSx 


Figure 15-27. RAM Array and Signal Generation 
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15.5.4.1 THE RAM WORD. The RAM word is a 32-bit wide micro-instruction that is stored 
in one of 64 locations in the RAM array. 


15.5.4.1.1 RAM Word Format. The RAM word format selects and specifies the timing of all 
external signals controlled by the user-programmable machine. 


RAM WORD 


Pow Faw [ow [aw [ow [ow fom pow fw [ow [ov [or] or | ow 


(MCRyap) INDIRECT ADDRESSING OF 1 OF 64 ENTRIES 


G4T4/ | G4T3/ 
jw [rw | rw | rw | ne [maw | ew | rw fon |r| rw | nw | on | | 
* 


NOTE: All 32 bits of the RAM word are addressed as shown in the address row above. 
— = Undefined. 


CST4—Chip-Select Timing 4 
This bit defines the state of the CSx signal during clock phase 1. 


O= The CSx signal is asserted at the trailing edge of GCLkK2. 
1 = The CSx signal is negated at the trailing edge of GCLK2. 


Note: The state of the selected CSx signal depends on the value of each CSTx bit and 
the corresponding bank. 





CST1—Chip-Select Timing 1 
This bit defines the state of the CSx signal during clock phase 2. 


0= The CSx signal is asserted at the rising edge of GCLK1. 
1= The CSx signal is negated at the rising edge of GCLK1. 


CST2—Chip-Select Timing 2 
This bit defines the state of the CSx signal during clock phase 3. 


0 = The CSx signal is asserted at the rising edge of GCLK2. 
1 = The C&Sx signal is negated at the rising edge of GCLK2. 
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CST3—Chip-Select Timing 3 
This bit defines the state of the CSx signal uiiie clock phase 4. 


-Q= The CSx signal is asserted at the trailing edge of GCLK1. 
1 = The C&x signal is negated at the trailing edge of GCLK1. 


BST4—Byte-Select Timing 4 
This bit defines the state of the BSx signal during clock phase 1. 


0 = The BSx signal is asserted at the trailing edge of GCLK2. 
1 = The BSx signal is negated at the trailing edge of GCLK2. 


Note: The state of each BSx signal depends on the value of each BSTx bit and three 
other parameter values—the PS field in the selected base register and the TSIZx 
and A[30:31] signals in the currently accessed cycle. 


BST1—Byte-Select Timing 1 
This bit defines the state of the BSx signal during clock phase 2. 


0 = The BSx signal is asserted at the rising edge of GCLK1. 
1 = The BSx signal is negated at the rising edge of GCLK1. 


BST2—Byte-Select Timing 2 
This bit defines the state of the BSx signal during clock phase 3. 


0 = The BSx signal is asserted at the rising edge of GCLK2. 
1 = The BSx signal is negated at the rising edge of GCLK2 


BST3—Byte-Select Timing 3 | | 
This bit defines the state of the BSx signal during clock phase 4. 


O= The BSx signal is asserted at the trailing edge of GCLK1. 
1 = The BSx signal is negated at the trailing edge of GCLK1. 


GOL—General-Purpose Line 0 Lower 
This field defines the state of the GPLO signal during phases 1 through 3. 


10 = The GPLO signal is asserted at the trailing edge of GCLK2. 

11 = The GPLO signal is negated at the trailing edge of GCLkK2. 

00 = The GPLO signal is driven at the trailing edge of GCLK2 as defined in the GOCLx 
field of the MxMR. 
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GOH—General-Purpose Line 0 Higher 
This field defines the state of the GPLO signal during phase 4. 


10 = The GPLO signal is asserted at the trailing edge of GCLK1. 

11 = The GPLO signal is negated at the trailing edge of GCLK1. 

00 = The GPLO signal is driven at the trailing edge of GCLK1 as defined in the GOCLx 
field of the MxMR. 


G1T4—General-Purpose Line 1 Timing 4 
This bit defines the state of the GPL1 signal during phases 1 through 3. 


O= The GPL1 signal is asserted at the trailing edge of GCLK2. 
1 = The GPL1 signal is negated at the trailing edge of GCLK2. 


Gi1T3—General-Purpose Line 1 Timing 3 
This bit defines the state of the GPL1 signal during phase 4. 





O0= The GPL signal is asserted at the trailing edge of GCLK1. 
1 = The GPL1 signal is negated at the trailing edge of GCLK1. 


G2T4— General-Purpose Line 2 Timing 4 
This bit defines the state of the GPL2 signal during phases 1 through 3. 


O0= The GPL2 signal is asserted at the trailing edge of GCLK2. 
1 = The GPL2 signal is negated at the trailing edge of GCLK2. 


G2T3—General-Purpose Line 2 Timing 3 
This bit defines the state of the GPL2 signal during phase 4 


O0= The GPL2 signal is asserted at the trailing edge of GCLK1. 
1 = The GPL2 signal is negated at the trailing edge of GCLK1. 


G3T4—General-Purpose Line 3 Timing 4 
This bit defines the state of the GPL3 signal during phases 1 through 3. 


oc. 
uu 
— 
— 
O 
oc 
-— 
2 . 
O 
oO 
> 
ao 
oO 
= 
Lu 
= 


1 5) 


0 = The GPL3 signal is asserted at the trailing edge of GCLK2. 
1 = The GPL3 signal is negated at the trailing edge of GCLK2. 





G3T3—General-Purpose Line 3 Timing 3 
This bit defines the state of the GPL3 signal during phase 4. 


0 = The GPL3 signal is asserted at the trailing edge of GCLK1. 
1 = The GPLS3 signal is negated at the trailing edge of GCLK1. 
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G4T4/DLT3—General-Purpose Line 4 Timing 4/Delay Time 3 

This bit performs two functions depending on the value of the GPLx4DIS bit in the machine 
mode register. If the MxMR defines the UPWAITx/GPL_x4 pin as an output (GPL_x4), then 
this bit functions as G4T4. If it is defined as an input ees) then this bit functions as 








DLT3. 


lf you have configured GPLx4DIS = 0 in the MxMR, then you have selected G4T4: 
O= The value of the GPL4 signal at the trailing edge of GCLK2 will be 0. 

1= The value of the GPL4 signal at the trailing edge of GCLK2 will be 1. 

If you have configured GPLx4DIS = 1 in the MxMR, then you have selected UPWAITx 
and DLT3 is the controlling function: 

0 = The data bus should be sampled at the rising edge of GCLK2 for all reads. 

1 = The data bus should be sampled at the falling edge of GCLK2 for all reads. 


G4T3/WAEN—General-Purpose Line 4 Timing 3/Wait Enable 


_ This bit performs two functions depending on the value of the GPLx4DIS bit in the machine 








mode register. If the MxMR defines the UPWAITx/GPL_x4 pin as an output (GPL_x4), then 
this bit functions as aa If it is defined as an input (UPWAITX), then this bit functions as 
WAEN. 


If you have configured GPLx4DIS = 0 in the MxMR, then you have selected G4T3: 


O= The value of the GPL4 signal at the trailing edge of GCLK1 will be 0. 
1 = The value of the GPL4 signal at the trailing edge of GCLK1 will be 1. 


If you have configured GPLx4DIS = 1 in the MxMR, then you have selected UPWAITx 
and WAEN is the controlling function: 


O= The UPWAITx function is disabled. 

1 = A “freeze” in the logical value of the UPM- controlled external signals will occur 
when the UPWAITx pin is asserted. The UPWAITx signal is sampled on the Ree 
edge of GCLK2. See Figure 15-33 for more information. 


G5T4—General-Purpose Line 5 Timing 4 
This bit defines the state of the GPL5 signal during phases 1 through 3. 





0 = The value of the GPL5 signal at the trailing edge of GCLK2 will be 0. 
1= The value of the GPLS signal at the trailing edge of GCLK2 will be 1. 


G5T3—General-Purpose Line 5 Timing 3 
This bit defines the state of the GPL5 signal during phase 4. 


0 = The value of the GPL5 signal at the trailing edge of GCLK1 will be 0. 
1 = The value of the GPL5 signal at the trailing edge of GCLK1 will be 1. 


Bits 22 and 23—Reserved 
These bits are reserved and should be set to 0. 
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LOOP—Loop 

The first RAM word in the RAM array where LOOP is 1 is recognized as the Loop Start Word. 
The next RAM word where LOOP is 1 is recognized as the Loop End Word. The RAM words 
between the start and end are defined as the loop. The UPM executes this loop as many 
times as it is defined in the corresponding loop field of the MxMR. 


O= The current RAM word is not the start or end of a loop construct. 
1 = The current RAM word is the start or end of a loop construct. 


EXEN—Exception Enable 

When an external device asserts the TEA or RESET signals, this bit allows you to branch to 
the exception start address (EXS) where you would store your exception handler. The 
exception start address is found at a fixed address in the RAM array. 





0 = The UPM continues executing the remaining RAM words. 

1 = The current RAM word allows a branch to an exception handler after the current 
cycle if an exception condition is detected. The exception condition can be an 
external device asserting TEA, HRESET, or SRESET. 


AMX—Address Multiplexing 
This bit determines the source of the A[0:31] signals. 


00 = The value of the A[6:31] signals at the trailing edge of GCLK1 is the address that 
is requested by the internal master. For example, column address. 

O1 = Reserved. 

10 = The value of the A[6:31] signals at the trailing edge of GCLK1 is the address that 
is requested by the internal master multiplexed according to the AMA/AMB field 
of the MxMR. For example, row address. 

11 = The value of the A[6:31] signals at the trailing edge of GCLK1is the contents of 
the memory address register (MAR). For example, SDRAM mode initialization. 


NA—Next Address a 
This bit determines how much the current address is incremented. 


O= The address increment is disabled | 
1 = In-conjunction with the PS field in the base register, the increment value of the 
A[28:31] signals at the trailing edge of GCLK1 is as follows: 
— Ifthe accessed bank has a 32-bit port size, the value of the A[28:31] signals are 
incremented by 4. | 
— lf the accessed bank has a 16-bit port size, the value of the A[28:31] signals are 
incremented by 2. 
— lf the accessed bank has an 8-bit port size, the value of the A[28:31] signals are 
incremented by 1. 


Note: The value of the NA bit is only relevant when the UPM serves a burst-read or 
burst-write request. Under other patterns this bit is reserved. 
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UTA—UPM Transfer Acknowledge 


This bit controls the state of the TA signal sampled by the external bus interface in the 
current memory cycle. The TA signal is output at the rising edge of GCLK2. : 


O= The TA signal is driven low on the next rising edge of GCLK2. 
1 = The TA signal is driven high on the next rising edge of GCLK2. 


TODT—Turn On Disable Timer 
This bit controls the disable timer mechanism. 


O= The disable timer is turned off. : 

1 = The disable timer for the currently accessed bank is activated. This prevents a new 
access to the same bank (when controlled by the UPMs) until the disable timer 
expires. For example, precharge time. 


LAST—Last 
If this bit is set, it is the last RAM word in the program. 


0 = The UPM continues executing RAM words. 
1 = The service to the UPM request is done. 


15.5.4.2 RAM WORD OPERATION. This section describes how the RAM word affects the 
behavior of the chip-select, byte-select, general-purpose, transfer acknowledgment signals, 
as well as address multiplexing and the wait mechanism. 


_ 15.5.4.2.1 Start Addresses. Each UPM request has a special address, except for software 
requests, which can start at any RAM word. Table 15-4 provides the start addresses of the 
UPM RAM words for each request type. 


@ 


Table 15-4. Start Address Locations 


REQUEST TO BE SERVICED UPM START ADDRESS 


Read Single Beat Cycle (RSS) 
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Write Single Beat Cycle (WSS) 
Write Burst Cycle (WBS) 
Periodic Timer Request (PTS) 
Exception (EXS) | 
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15.5.4.2.2 Chip-Select Signals. The MS field in the base register of the accessed memory 
bank selects a user-programmable machine on the currently requested cycle. The selected 
UPM only affects the assertion and negation of the appropriate CSx signal and its timing is 


specified in the UPM RAM word. Figure 15-28 illustrates how the CSx signals are controlled 
by the UPMs. | 
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Figure 15-28. CSx Signal Selection 
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15.5.4.2.3 Byte-Select Signals. The MS field in the base register of the accessed memory 
bank selects a user-programmable machine on the currently requested cycle. The selected 
UPM only affects the assertion and negation of the appropriate BSx signal and its timing as 
specified in the RAM word. The BSx signals are also controlled by the port size of the 
accessed bank, the transfer size of the transaction, and the address accessed. Figure 15- 
29 illustrates how the BSx signals are controlled by the user-programmable machines. 


BANK SELECTED 


A(30:31] 


MS IN BRx PS IN BRx TSIzx 


| BSO 
BYTE- = 
MUX SELECT a 
LOGIC BS2 
: BS3 
~ UPMB | 


Figure 15-29. BSx Signal Selection 
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The uppermost byte select (BSO) indicates that the most-significant eight bits of the data bus 
(DO-7) contain valid data during a cycle and the upper-middle byte-select (BS1) indicates 
that the upper-middle eight bits of the data bus (D[8-15]) contain valid data during a cycle. 
The lower-middle byte-select (BS2) indicates that the lower-middle eight bits of the data bus 
(D[16-23]) contain valid data during a cycle and the lowest byte-select (BS3) indicates that 
the least-significant eight bits of the data bus (D[24-31]) contain valid data during a cycle. 
The manner in which the BSx signals affect 32-, 16-, and 8-bit accesses is shown in 

Table 15-5. It should be noted that for a periodic timer request and a memory command 
request, the BSx signals are only determined by the port size of the bank. 


Table 15-5. Enabling Byte-Selects 


TRANSFER | TSIZx | ADDRESS | 32-BIT PORT SIZE 16-BIT PORT SIZE 8-BIT PORT SIZE 
SIZE 
aso] ast | ps0 ost 852] ss 50] ost 552/850 ns0| ast] es2| eso 


REE ERE EE x 
ae E23 ee 


Half-Word 1 
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15.5.4.2.4 General-Purpose Signals. The general-purpose (GPL[1:5]) signals have two 
bits in the RAM word that define the logical value of the signal to be changed at the falling 
edge of GCLK1 or GCLK2. GPLO has two 2-bit fields that perform the same function with 
additional phase control. GPL5 and GPLO offer the following enhancements beyond the 
other GPLx signals: 








¢ GPL5 can be controlled during phase 4 of the previous clock cycle according to the 
value of G5SLS. . : 


CLKOUT/GCLK2 | | | | | | | | | 
| 
7 | | | | 
GCLK1 : | | | i | 
| | 
| 


| 

" eG | | | 

| | | | | | 

! ee 
| | | | | VALUE CONTROLLED | 


| | |! ay asth ano e573 On upM | 
VALUE CONTROLLED y | | | | 
BY GS5LS is | 


| | | | | | | 
| | | | | | | | 
| | | | | | | | 
CLOCK PHASE La oT 4 a By Se UP a ee | 
| | | | | | | | 
| | | | | | | | 
| | ] | l 





RAM WORD 1 RAM WORD 2 


Figure 15-30. Early GPL5 Control 


e GPLO can be controlled by an address line that is specified in the GOCLx field of the 
MxMR. To use this feature, you must set the GOH and GOL fields in the RAM word. For 
example, if you have a SIMM with multiple banks, this address line can be used to 
switch between banks. 
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15.5.4.2.5 Loop Control. The LOOP bit in the RAM word allows you to run a repetitive 
program fragment a specific number of times. The first time the LOOP bit is asserted in a 
RAM word, the memory controller recognizes it as a Loop Start Word. At this time, the 
memory loop counter is loaded with the corresponding contents of the LOOP bit shown in 
Table 15-6. The next RAM word encountered with the LOOP bit set is recognized as a Loop 
End Word. At this time, the memory loop counter is decremented by one. 


Continued loop execution depends on the memory loop counter. If the loop counter is not 

zero, the next RAM word executed is the Loop Start Word. Otherwise, the next RAM word 
executed is the word following the Loop End Word. Loops can be sequentially executed, but 
not nested. 


Table 15-6. MxMR Loop Bit Usage 


Write Single Beat Cycle 
Write Burst Cycle 
Periodic Timer Expired 


15.5.4.2.6 Exception Handling. When an access to a memory device is initiated by the 
MPC823 under UPM control, the external device may assert the TEA, SRESET, or HRESET 
signal. An exception occurs when one of these signals is asserted by an external device and 
the MPC823 begins closing the memory cycle transfer. When an exception is recognized 
and the EXEN bit is set in the RAM word, the next RAM word will branch to the special 
exception start address (EXS). See Table 15-4 for more information. You should provide an 
exception handler to handle output signals controlled by the UPM. For DRAM control, you 
would provide a handler that would negate RAS and CAS to prevent data corruption. The 
EXEN bit is similar to an exception mask in that if it is 0, then it defers the exception and 
continues executing. Ifa RAM word is encountered with the EXEN bit set, the UPM performs 
a branch to the exception start address. When the branch to the exception start address is 
performed, the UPM continues reading until the LAST bit is set in the RAM word. 
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15.5.4.2.7 Address Multiplexing. You can control which address signals go to the 
external bus. The AMA and AMB fields of the MxMR control how the address signals are 
multiplexed. The SAM bit in the option register determines the address multiplexing for the 
first clock cycle. The AMX field in the RAM word determines the multiplexing for subsequent 
clock cycles. The lower address pins can be multiplexed between the internal upper or lower 
address signals. The SAM bit outputs the upper address signals and the AMX field outputs 
the lower address signals. Using the AMX field, you can output the contents of the memory 
address register (MAR) on the address pins. See Table 15-6 for general configuration. 
Table 15-7 shows how the AMA and AMB fields can be defined to interface with a wide 
range of DRAM modules. Figure 15-31 illustrates address multiplex timing. 


CLKOUT/GCLK2 | | | | | 


GCLK1 

| | | 
A{0:31] | UPPER ADDRESS | LOWER ADDRESS | 
7 | | | 











ADDRESS CONTROLLED | ADDRESS CONTROLLED | 
| =BYSAM | BYAMX | | 
| | | | 
' RAM WORD 1 | RAM WORD 2 | 


Figure 15-31. Address Multiplex Timing 


Table 15-7. Address Multiplexing 
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Table 15-8. AMA/AMB Definition For DRAM Interface 
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Table 15-8. AMA/AMB Definition For DRAM Interface (Continued) 


DATA BUS MEMORY NUMBER OF NUMBER OF MPC823 AMA/AMB 
WIDTH SIZE DRAM ROW: DRAM COLUMN ADDRESS PIN IN MxMR 
ADDRESS PINS ADDRESS PINS CONNECTION 


[—as0e [8 


i 


— A20 - A380 


= 
_m 
= 
2) 
=e) 
=< 
?) 
2) 
<= 
—| 
BS) 
1.2) 
r— 
is 
m 
sv) 








15-62 ‘-MPC823 USER’S MANUAL MOTOROLA 


Memory Controller 


Table 15-8. AMA/AMB Definition For DRAM Interface (Continued) 


DATA BUS MEMORY NUMBER OF NUMBER OF MPC823 AMA/AMB 
WIDTH SIZE DRAM ROW DRAM COLUMN ADDRESS PIN IN MxMR 
ADDRESS PINS | ADDRESS PINS CONNECTION 
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15.5.4.2.8 Transfer Acknowledge and Data Sample Control. During a memory access, 
the UTA bit of the RAM word controls the state of the TA signal sampled by the bus master. 
The TA signal is driven on the rising edge of GCLK2. When a read access is handled by the 
UPM and the UTA bit is 0, the value of the DLTS bit in the same RAM word indicates when 


_ the data input is sampled by the bus master, assuming that the GPLx4DIS bit is set in the 


MxMR. Figure 15-32 illustrates the data sampling that is controlled by the UPM. 






TO INTERNAL 
DATA BUS 


MULTIPLEXER 


il 






DATA BUS 


DLT3 AND GPLADIS 


“Figure 15-32. UPM Read Access Data sampling 


— 15.5.4.2.9 Disable Timer Mechanism. The disable timer associated with each UPM 
_ allows you to guarantee a minimum time between two successive accesses to the same 


memory bank. This feature is critical wnen DRAM requires a RAS precharge time. The 
TODT bit in the RAM word turns the timer on to prevent another UPM access to the same 
bank until the timer expires. 


The disable timer does not affect memory accesses to different banks. If the timing specified 
by the UPM RAM word is less than the disable timer period, the access to the next bank will 
conflict with the current bank access. To avoid conflicts between different banks using the 
same UPM, the number of words in the RAM array must be equal to or greater than the 
period defined in the DSx field of the MxMR. 


15.5.4.2.10 Last Word. When the LAST bit is read in a RAM word, the highest priority 
pending request (if any) is serviced immediately in the external memory transactions. If the 
disable timer is activated, the bus will be idle for a number of clock cycles as aes in the 
DSx field of the MxMR. 
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15.5.5 The Wait Mechanism 


If the UPM reads a RAM word with the WAEN bit set, the external UPWAITx signal is 
sampled and synchronized by the memory controller and the current request is frozen. If the 
WAEN bit is asserted, the logical value of the external signals are frozen to the value defined 
in the last RAM word accessed and the RAM address increment is disabled until the 
UPWAITx signal is negated. This allows wait states to be inserted as required by an external 
device through an external signal. A memory disable timer is associated with each UPM. 
This timer counts down to zero starting at the value programmed in the DSx field in the 
MxMR. 


15.5.5.1 INTERNAL AND EXTERNAL SYNCHRONOUS MASTER. Figure 15-33 
illustrates how the WAEN bit in the word read by the UPM and the UPWAITx signal is used 
to hold the UPM in a particular state until the UPWAITx signal is negated. As illustrated in 
Figure 15-33, the CSx and GPL1 states (C12 and F)} and the WAEN value (CC) are frozen 
until the UPWAITx signal is recognized as deasserted. 


CLKOUT | | | | | | | | | | 


GCLK1 


GCLK2 | | | _ | — | 








' Toyo Tt 
| | 
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| | | ~ | 
| RAM WORD N | RAM WORD N+1 RAM WORD N+2 | WAIT | _ WAIT RAM WORD N+3 


JSEIgure 15-33. Wait Mechanism Timing For Internal and External 
Synchronous Masters 
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The UPWAITx signal is sampled at the falling edge of the CLKOUT. If the signal is asserted 
and the WAEN bit is set in the current RAM word, the UPM is frozen until the UPWAITx 
signal is recognized as negated. The value of the external pins driven by the UPM remains 
as indicated in the word previously read by the UPM. When the UPWAITx signal is negated, 
the UPM continues with its normal functions. Notice that during the wait cycles, the TA signal 
is negated by the UPM. — | | 


15.5.5.2 EXTERNAL ASYNCHRONOUS MASTER. The UPM supports asynchronous 
external masters using the AS signal. When you use an external asynchronous master, the 
AS signal behaves like the UPWAITx signal. The UPM enters a wait state if the AS signal is 
asserted and the WAEN bit is set in the current RAM word. As illustrated in Figure 15-34, 
the CSx and GPL1 states (C12 and F) and the WAEN value (CC) are frozen until the AS 
signal is recognized as deasserted. The TA signal that is driven by the UPM remains in its 
previous value until the AS signal is negated. The state of the external pins driven by the 
UPM remains as indicated in the word previously read by the UPM. 





To exit a wait state, the AS signal should be negated. When AS is negated, all external 
signals controlled by the UPM are driven high. The external signals are driven in this state 
until the LAST bit is set ina RAM word. The TODT bit is only relevant in the words read by 
the UPM after the AS signal is negated. Refer to Section 15.6 External Master Support 
for more information. 
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Figure 15-34. Wait Mechanism Timing For An External Asynchronous Master — 


15-66 MPC823 USER’S MANUAL MOTOROLA 


Memory Controller 


15.5.5.3 HANDLING VARIABLE ACCESS TIME AND SLOW DEVICES. The memory 
controller provides two different mechanisms to interface with slave devices that either are 
very slow or cannot guarantee a predefined access time—the wait state and the external TA 
signal. These devices can be divided into two main types: 


¢ Variable access time devices (FIFO, hierarchical bus interface, dual-port memory 
devices) 


e Slow devices (access time is greater than the maximum allowed by the UPM) 


The wait mechanism is used only in accesses that are controlled by the UPM. The 
GPLx4DIS bit of the MxMR enables this mechanism. The external TA mechanism is used 
only in accesses that are controlled by the GPCM. The SETA bit in the option register 
specifies whether the TA is generated internally or externally. 


15.5.5.3.1 Hierarchical Bus Interface Example. On the local bus, the CPU initiates a 
read cycle that addresses the main storage connected to the system bus. The hierarchical 
bus interface accepts the local bus request and generates a read cycle on the system bus. 
You cannot foresee when the data will be valid to be latched by the CPU since the system 
bus may be occupied by the DMA. 


e The Wait Solution—The external module signals to the memory controller that the data 
is not ready yet by asserting the UPWAITx signal. The memory controller synchronized 
this signal since it is an asynchronous signal. As a result of the UPWAITx signal being 
asserted, the UPM will enter a freeze mode at the falling edge of the CLKOUT upon 
encountering the WAEN bit being set in the UPM word. The UPM will remain in that 
state until the UPWAITx signal is asserted. After the negation of UPWAITx, the UPM 
will continue executing from the next entry to the end of the pattern (LAST bit is set). 


¢ The External TA Solution—The bus interface module signals to the memory controller 
when it can sample the data by asserting the synchronous TA signal. 


15.5.5.3.2 Slow Device Interface Example. The CPU initiates a read cycle from slow 
devices whose access time is greater than the maximum allowed by your programming 
model. 


MEMORY CONTROLLER 


e The Wait Solution—The CPU generates a read access from the slow device. The 
device will react by asserting the UPWAITx signal as long as the data is not ready. The 
CPU will sample the data only after the negation of the UPWAITx signal. 


¢ The External TA Solution—The CPU generates a read access from the slow device. 
When it is ready, the device is responsible for generating the synchronous TA signal. 


@ 
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15.6 EXTERNAL MASTER SUPPORT | 


The memory controller supports internal and external bus masters. Accesses that originate 
from the core, CPM, and LCD controller are considered internal and those initiated by an 
external bus master are external. External bus master support can be enabled in the SIU 
module configuration register (SIUMCR), as indicated in Section 12.12.1.1 SIU Module 
Configuration Register. There are two types of external bus masters: 


¢ Synchronous bus masters synchronize with CLKOUT and may use the MPC823 
memory controller to access a slave device or bypass the memory controller to perform 
the slave access. 


e Asynchronous bus masters use an address strobe (AS) signal that handshakes with the 
MPC823 memory controller to aACCess a slave device or bypass the memory controller 
to perform the slave access. 


Synchronous masters initiate a transfer by asserting the TS signal. The A[6:31], RD/WR, 
and TSIZx signals must be stable prior to the rising edge of CLKOUT after TS assertion and 
until the last TA signal is negated. Since the external master operates synchronously with 
the MPC823, proper setup and hold times for all inputs associated with the rising edge of 
CLKOUT are significant. To support synchronous mode using the memory controller, the 
SEME bit in the SIUMCR must be set. When the TS signal is asserted, the memory 
controller compares the address with each one of its defined valid banks and if a match is 
found, control signals to the slave device are generated and the TA signal is supplied to the 
external master. If the SEME bit is cleared, the memory controller is bypassed and the 
external synchronous master must provide control signals to the slave device. See 

Figure 15-35 for details. | 7 : 


Asynchronous masters initiate a transfer by driving the address bus and asserting the AS 


pin. The 2 A[6:31] signals, together with RD/WR and TSIZx, must have a proper setup time 


prior to AS pin assertion. To support asynchronous mode using the memory controller, the 
AEME bit in the SIUMCR must be set. The memory controller synchronizes AS assertion to 
its internal clock and generates the control signals to the slave device. When the AS pin is 
synchronized, the memory controller compares the address with each one of its defined. 
valid banks and if a match is found, control signals to the slave device are generated and 
the TA signal is supplied to the external master. All the control signals to the memory device 
and the TA signal are negated with AS pin negation. If the AEME bit is cleared, the memory 
controller is bypassed and the external asynchronous master must provide control signals 
to the slave device. In this mode, the AS pin of the MPC823 | is not available as an input. See 
Figure 15-36 for details. 


= Note: When external masters access slaves on the bus, the internal AT[0:2] signals 
reaching the memory controller will be forced to ‘100’. You should make sure this 
access matches the AT field in the base register after it is masked by the ATM 
field in the option register. 
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The A[28:20] pins should be used to generate addresses to memory devices during burst 
accesses. They duplicate the value of the A[28:20] signals when an internal master initiates 
a transaction on the external bus. When an external master initiates a transaction on the 
external bus, the A[28:20] pins reflect the value of the A[28:20] pins on the first clock cycle 
of the memory access. On subsequent clock cycles, the behavior of the A[28:20] pins 
depends on the configuration of the UPM. 
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Figure 15-35. Synchronous External Master Access 
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Figure 15-36. Asynchronous External Master Access 


To connect to external memory devices that require address multiplexing, use the GPL_x5 
pin. The state of the GPL_x5 signal logic value depends on the configuration defined in 
Table 15-9. The GPL_x5 pin reflects the value of the G5LS bit of the corresponding option 
register in the first clock cycle of the slave device access. In subsequent clock cycles, the 
state of GPL_x5 is determined by the G5T4 and G5T3 bits in the RAM word. If the UPMB 
controls the slave access, you can use the G5LA bit of the option register to select the active 
GPL_x5 signal. G5LS only applies to memory requests and not RAM words executed by 
internal/external software, exception, or memory periodic timer requests. 
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Table 15-9. GPL_x5 Signal (Pin) Behavior 
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15.6.1 External Master Examples 


A synchronous example interconnection in which an external master and the MPC823 can 
both share access to a DRAM bank is illustrated in Figure 15-37. Notice that CS1, UPMA, 
and GPL_A5 were chosen to assist in the control of DRAM bank accesses. To perform burst 
accesses initiated by the external master or MPC823 using this configuration, the A[28:30] 
signals are connected to the multiplexer controlled by GPL_A5. Figure 15-38 illustrates the 
timing behavior of control signals when an external master to a DRAM bank initiates a burst 
read access. The state of the GPL_AS5 pin in the first clock cycle of the memory device 
access is determined by the value of the G5LS bit in the corresponding option register. In 
this example, the accessed critical word is addressed at A[28:29] = 10, which then | 
increments and wraps around to the word before the critical word (01) for subsequent beats 
of this burst access. | | 
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Figure 15-37. Synchronous External Master Interconnect Example 
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An asynchronous example interconnection in which an external master and the MPC823 
can both share access to a DRAM bank is illustrated in Figure 15-39. Notice that CS1, 
UPMA, and GPL_A5 were chosen to assist in the control of DRAM bank accesses. 

Figure 15-40 illustrates the timing behavior of the GPL_A5 and other control signals when 
an external master to a DRAM bank initiates a single beat read access. The state of the 
GPL_AS pin in the first clock cycle of the memory device access is determined by the value 
of the G5LS bit in the corresponding option register. 
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Figure 15-39. Asynchronous External Master Interconnect Example 
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Figure 15-40. Asynchronous External Master Timing Example 
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15.7 MEMORY SYSTEM INTERFACE EXAMPLES 


The following examples illustrate how to connect and set up the UPM RAM array for two 
types of DRAM—page mode DRAM and page mode extended data out DRAM. The values 
used in these examples apply to either UPMA or UPMB. UPMA is used in the page mode 
example and UPMB is used in the extended data out example. 


15.7.1 Page Mode DRAM Interface Example 


The configuration for a 1M, 32-bit wide memory system using four 256K x 8-bit DRAMs is 
illustrated in Figure 15-41. Also shown is the physical connection between UPMA and the 
page mode DRAM. The CS7 signal is connected to all the RAS signals and controlled by 
the base register. The BS_A[0:3] signals are mapped one-to-one to each of the four DRAMs 
and are controlled by the UPM RAM word. The refresh rate is calculated based on a 25MHz 
baud rate generator clock and the DRAM that requires a 512-cycle refresh every 8ms. 





256K x 8 206K x 8 
MCM84256 |_ MCM84256 


D{0:7] 


MCM84256 MCM84256 
256K x 8 W 256K x 8 


~ MPC823 





Figure 15-41. Page Mode DRAM Interface Connection 


Follow these steps to configure a system for page mode DRAM: 
1. Determine the system architecture, which includes the MPC823 and the memory 
system as shown in the example in Figure 15-41. 


2. Use the blank worksheet in Figure 15-58 to draw the timing diagrams for all the 
memory cycles associated with your architecture. You can also use as a reference the 
various other timing diagrams in Figure 15-42 through Figure 15-50. 
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3. Translate the timing diagrams into RAM words for each type of memory access. The 
bottom half of the figures represent the RAM array contents that handle each of the 
possible cycles and each column represents a different word in the RAM array. A 
blank cell in the figures indicates a “don’t care” bit, which is typically programmed to 
logic 1 to conserve power. 


4. Define the UPMA (or UPMB) parameters that control the memory system in the 
following sequence. For additional details, see Table 15-10. 

— Program the RAM array using the memory command register (MCR) and 
memory data register (MDR). The RAM word must be written into the MDR 
before you issue the WRITE command to the MCR. Repeat this step for all RAM 
word entries. 

— Initialize the option and base registers of the specific bank according to the 
address mapping of the DRAM device you have chosen. 

— Use the MS field of the option register to select the machine you have chosen 
to control the cycles. Notice that the SAM bit in the option register determines 
address multiplexing for the first clock cycle and subsequent cycles are 
controlled by the UPM RAM words. Also notice that the AMX field in the UPM 
RAM word controls the address multiplexing for the next clock cycle rather than 
the current cycle. 

— Program the MAMR to select the number of columns and refresh timer 
parameters. 


Table 15-10. UPMA Register Settings 
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Figure 15-42. Single Beat Read Access To Page Mode DRAM 
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Figure 15-43. Single Beat Write Access To Page Mode DRAM 


MOTOROLA MPC823 USER’S MANUAL 15-79 


-Memory Controller 


CLKOUT/GCLK2 





GCLKt | | Tle ae a | | | | | 
a | | | |: | | | | | 

. | 

(ums Xf coume {caus {cue 

: : | 

+5 \ | i | | | | | | | | 
| | | | | | | | | 


Al6:31] 








| | 

| F 

oo | | | | | 

(RAS) | | | | | | | 

_ | | | | 

BS_A(0:3] | | | | | ee | | | 
(CAS[0:3)) | | | 


@ 


YATIOULNOOD AYOWAW 





PT ee 
a 
eT ee 
Li 
PT ee 
eT ee 
eT ee 


RBS+1 | RBS+2 


Figure 15-44. Burst Read Access To Page Mode DRAM (No LOOP) 
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Figure 15-45. Burst Read Access To Page Mode DRAM (LOOP) 
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Figure 15-46. Burst Write Access To Page Mode DRAM (No LOOP) 
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Figure 15-47. Burst Write Access To Page Mode DRAM (Loop) 
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Figure 15-48. Refresh Cycle (CAS Before RAS) To Page Mode DRAM 
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Figure 15-49. Exception Cycle 
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You can significantly increase the performance of a page read access when you set 
GPLA4DIS to 1 in the MAMR and ignore the GPL_A4 pin. The processor samples the data 
bus at the falling edge of GCLK1 when the TA signal is asserted. Figure 15-50 illustrates 
how to modify the burst read access to page mode DRAM (no loop) using this feature. 
During the four consecutive data beats, the TA signal in the figure is asserted to ensure a 
data transfer on every data clock. The figure also illustrates how the nine cycles of the burst 
read access shown in Figure 15-43 can be reduced to 6 clock cycles (for 32-bit port size 
memory). You can reduce the cycles by using faster DRAM or a slower system clock that 
meets the DRAM access time. When a 16-bit port size memory is connected, the reduction 
is from 17 to 10 cycles and when an 8-bit port size memory is connected, the reduction is 
from 33 to 18 cycles. 
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Figure 15-50. Optimized DRAM Burst Read Access 
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15.7.2 Page Mode Extended Data-Out DRAM Interface Example 


The configuration for a 1M, 32-bit wide memory system using two 256K x 16-bit page mode 
extended data-out (EDO) DRAMs is illustrated in Figure 15-51. Also shown is the physical 
connection between UPMB and the EDO DRAMs. The CS2 signal that is controlled by the 
base register is connected to both of the RAS signals. The BS_B[0:1] signals are mapped 
to the lower DRAM (D[0:15]) and the BS_B[2:3] signals are mapped to the upper DRAM 
(D[16:31]). For this connection, GPL_B1 is connected to the memory device OE pins. The 
refresh rate is calculated based on a 25MHz baud rate generator clock and the DRAM that 
requires a 512-cycle refresh every 8ms. 








MT4C016270 MT4C16270 
MPC823 | 256K X 16 256K X 16 
OE 





cy 


Figure 15-51. EDO DRAM Interface Connection 


Follow these steps to configure a system for EDO DRAM: 


1. Determine the system architecture, which includes the MPC823 and the memory | 
system as shown in the example in Figure 15-52. 
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2. Use the blank worksheet in Figure 15-58 to draw the timing diagrams for all the | 
memory cycles associated with your architecture. You can also use as a reference the 
various other timing diagrams in Figure 15-52 through Figure 15-57. 


3. Translate the timing diagrams into RAM words for each type of memory access. The 
bottom half of the figures represent the RAM array contents that handle each of the 
possible cycles and each column represents a different word in the RAM array. A 
blank cell in the figures indicates a “don't care” bit, which is typically programmed to 
logic 1 to conserve power. | 
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4. Define the UPMB (or UPMA) parameters that control the memory system in the 
following sequence. For additional details, see Table 15-11. 


— Program the RAM array using the memory command register (MCR) and 
memory data register (MDR). The RAM word must be written into the MDR 
before you issue the WRITE command to the MCR. Repeat this step for all RAM 
word entries. 

— Initialize the option and base registers of the specific bank according to the 
address mapping of the DRAM device you have chosen. 

— Use the MS field of the option register to select the machine you have chosen 
to control the cycles. Notice that the SAM bit in the option register determines 
address multiplexing for the first clock cycle and subsequent cycles are 
controlled by the UPM RAM words. Also notice that the AMX field in the UPM 
RAM word controls the address multiplexing for the next clock cycle rather than 
the current cycle. | 

— Program the MBMR to select the number of columns and refresh timer 
parameters. 


Table 15-11. UPMB Register Settings 
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Figure 15-52. EDO DRAM Single Beat Read Access 
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Figure 15-53. EDO DRAM Single Beat Write Access 
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Figure 15-54. EDO DRAM Burst Read Access 
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Figure 15-55. EDO DRAM Burst Write Access 
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Figure 15-56. EDO DRAM Refresh Cycle (CAS Before RAS) 
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Figure 15-57. EDO DRAM Exception Cycle 
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Figure 15-58. Blank Worksheet for a UPM 


15-96 -MPC823 USER’S MANUAL MOTOROLA 


SECTION 16 
COMMUNICATION PROCESSOR MODULE 


The MPC823 communication processor module (CPM) provides a flexible and integrated 
approach to communication-intensive environments. To reduce system frequency and save 
power, the communication processor module has its own independent RISC microcontroller 
that is optimized and tuned to handle serial communications. The communication processor 
module offloads the core in the following ways: 


e By reducing the interrupt rate. The core is interrupted only upon frame reception or 
transmission, instead of on a per-character basis. 


e By implementing some of the Layer-2 multiply-and-accumulate processing, which 
provides more CPU bandwidth for higher layer processing. 


e By supporting multibuffer memory data structures that are convenient for software 
handling. 


The communication processor module in the MPC823 and MPC821 are similar and are both 
derived from the communication processor module in the MC68360 QUICC. However, there 
are distinct differences, which are discussed in this section. 


16.1 FEATURES 


The following is a list of the communication processor module’s main features. For quick 
reference purposes, the superscripted number following each item below is the page 
number where the feature is described. 


¢ 32-Bit RISC Microcontroller* 

e Flexibility of Four General-Purpose 16-Bit Timers or Two 32-Bit Timers”® 
¢ A Serial Interface with a Time-Slot Assigner ''9 

¢ Four Independent Baud Rate Generators'®" 

e A Full-Duplex Serial Communication Controller (GCC2)1'9%” 

e A Universal Serial Bus Controller?*? 

¢ Two Full-Duplex Serial Management Controllers (GMCs)?”2 

¢ Serial Peripheral Interface (SPI) Support for Master or Slave*29 

¢ |?C Bus Controller Support for Master or Slave*6 

¢ General-Purpose Parallel Interface Ports with Open-Drain Capability*®’ 
¢ Communication Processor Module Interrupt Controller with Flexible Priorities*®” 
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Communication Processor Module 


The following blocks and protocols contain primary programming functionalities that use 
parameter RAM tables as their communication interface. 


e RISC microcontroller 


L} Dual port RAM 

Li RISC timer table 
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~« Serial communication controller 


UART protocol 
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Asynchronous HDLC protocol 
Infra-red protocols 
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Ethernet protocol 
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e Universal serial bus controller 
e Serial management controllers 


1 UART protocol 
1 Transparent protocol 
1 GCI protocol 


e Serial peripheral interface 
© |?C bus controller _ 
¢ General-purpose parallel interface ports 
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The block diagram of the communication processor module is illustrated in Figure 16-1. 
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Figure 16-1. CPM Block Diagram 
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Communication Processor Module 


The MPC823 offers an extremely flexible set of communication capabilities. The remainder 
of this section discusses all the possible ways you can configure the communication 
processor module. Figure 16-2 illustrates a sample configuration for a personal digital 
assistant (PDA) application that supports various communication links and protocols. 
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Figure 16-2. Example of a PDA Application 


16.2 THE RISC MICROCONTROLLER 


The 32-bit RISC microcontroller for the communication processor module resides on a 
separate bus from the core and, therefore, does not impact the core’s performance. The 
microcontroller operates in conjunction with the serial channels and parallel port to 
implement the user-programmable protocols and manage the serial DMA (SDMA) channels 
that transfer data between the I/O channels and memory. The RISC microcontroller 
architecture and instruction set are optimized for data communication and data processing 
functions that are required by many wire-line and wireless communication standards. The 
microcontroller also contains a multiply and accumulate (MAC) unit composed of a 16x16-bit 
multiplier with two 40-bit accumulators that enable you to implement many DSP 
applications. 


Basically, the microcontroller handles low-level arithmetic tasks and DMA control activities, 
which leaves the core free to handle the high-level activities. You could say it is the controller 
of the communication processor module. It manages IDMA channel operation and contains 
an internal timer that you can use to implement a maximum of 16 additional software timers. 
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16.2.1 RISC Microcontroller Features 


The following is a list of the RISC microcontrollers main features. 


e One System Clock Cycle Per Instruction 

e Fixed-Length Instruction Object Code 

e Code Is Executed from Internal ROM or Dual-Port RAM 
e Automatically Switches to Low-Power Mode When Idle 
e 32-Bit Data Path 

e Optimized for Communication Processing 


e Digital Signal Processing Capability Using MAC Arithmetic and Special 
Addressing Modes | 


e DMA Bursts Serial Data to External Memory | 
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Figure 16-3. RISC Microcontroller Block Diagram 
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16.2.2 Communication Between the Microcontroller and Core 


The RISC microcontroller communicates with the core in the following ways: 


¢ By exchanging parameters using the 8K dual-port RAM. With simultaneous accesses, 
the microcontroller experiences a one-clock delay when accessing the dual-port RAM, 
but the host is never delayed. 


¢ By executing special commands that are issued by the host via the CPM command 
register (CPCR). These commands should only be issued in special situations like 
exceptions or error recovery. 


By generating interrupts using the CPM interrupt controller. 


¢ By allowing the core to configure the CPM via the RISC controller configuration register 
(RCCR) | 


¢ By allowing the core to read the CPM status and event registers at any time. 


The core communicates with the communication processor module by configuring the 
RCCR. 


16.2.3 Communication Between the Microcontroller and Peripherals 


The RISC microcontroller uses the peripheral bus to communicate with all of its peripherals. 
The serial communication controller (SCC2) and universal serial bus (USB) have separate 
receive and transmit FIFOs. The SCC2 and USB FIFOs are 16 bytes each. However, the 
serial management controller, serial peripheral interface, and I?C FIFO sizes are all — 
double-buffered. The following prioritized list contains the processing order of the 
microcontroller from highest to lowest priority. 


. Reset in CPM command register or at reset 

. SDMA bus error —— 
. Commands issued to the command register, including DSP-related commands 
. IDMA DREQ1 (default setting) 

IDMA DREQ2 (default setting) 

USB Reception (RX) 

USB Transmission (TX) 

SCC2 RX 

. SCC2 TX es 

10.IDMA DREQ1 (option 2). 

11. IDMA DREQ2 (option 2) 


© ONOTAR ON 


38 12,.SMC1 RX 
ae 13.SMC1 TX 
28 14. SMC2 RX 
ge 15.SMC2 TX 
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16.SPI RX 

17.SPI TX 

18.1°C RX 

19.1?C TX 

20.RISC timer tables 
21.IDMA DREQ1 (option 3) 
22.IDMA DREQ2 (option 3) 


16.2.4 Executing Microcode From RAM or ROM 


The microcontroller can execute microcode from a portion of 8K dual-port RAM. Depending 
on the size of your microcode, you can program the ERAM field in the RCCR to protect the 
first 512 bytes, 1,024 bytes, or 2,048 bytes of on-chip RAM to allow the microcontroller 

exclusive access. You can execute microcode from the dual-port RAM or on-chip ROM. This 
flexibility not only allows Motorola to add more protocols or enhancements to the MPC823, 
but it also allows you to obtain binary microcode. Refer to Table 16-1 for more information. 


16.2.5 RISC Microcode Development Support Control Register 


The RISC microcode development support control (RMDS) register determines which 
regions of the dual-port RAM can contain executable microcode. This register is used in 
conjunction with the ERAM field in the RCCR to determine the valid address space for 
executable microcode. 


RMDS 


ERAM4K os RESERVED | 
(IMMR & OxFFFFO000) + 0x9C7 


ERAM4K—Enable RAM Microcode (4k) 


0 = Microcode program execution may be executed only from the first 2,048 bytes of 
the dual-port RAM. 

1= Microcode is also executed from the 2,048 bytes of the second half of the dual-port 
RAM with a 512-byte extension. 












Bits 1-7—Reserved 
These bits are reserved and should be set to 0. 
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Communication Processor Module 


16.2.6 RISC Controller Configuration Register 


The 16-bit, memory-mapped, read/write RISC controller configuration register (RCCR) 
configures the microcontroller to run microcode from ROM or RAM and controls the RISC 
internal timer. This register is initialized to zero at reset. 


RCCR 


S85 3 = 
DR1M DROP ERAM 


(IMMR & OxFFFO000) + 0x9C4F 





TIME—Timer Enable 


This bit controls whether the microcontroller’s internal timer can send a tick to the 
microcontroller based on the value programmed into the TIMEP bit. 


0 
1 


Stop RISC timer table scanning. 
Start RISC timer table scanning. | 


Bit 1—Reserved 
This bit is reserved and should be set to 0. 


TIMEP—Timer Period 


This field controls the microcontrollers timer tick. The RISC timer tables are scanned on 
each timer tick and the input to the timer tick generator is the general system clock divided 
by 1,024. The formula is (TIMEP + 1) x 1,024 = (general system clock period). Thus, a value 
of 0 stored in these bits gives a timer tick of 1 x (1,024) = 1,024 general system clocks and 
a value of 63 (decimal) gives a timer tick of 64 x (1,024) = 65,536 general system clocks. 


DR2M—IDMA Request 2 Mode 
This bit controls the IDMA request 1 (DREQ2) sensitivity mode. 


0 = DREQ2 is edge-sensitive. 
1 = DREQ2 is level-sensitive. 


DR1M—IDMA Request 1 Mode 
This bit controls the IDMA request 0 (DREQ1) sensitivity mode. 


0 = DREQ1 is edge-sensitive. 
1 = DREQ1 is level-sensitive. 
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DRQP—IDMA Emulation Request Priority 


This field controls the priority of the external requests signals that relate to the serial 
channels. Refer to Section 16.2.3 Communication Between the Microcontroller and 
Peripherals for more information. 


00 = IDMA requests have priority over the serial communication controller and USB 
(default). 

01 = IDMA requests have priority immediatley following the serial communication 
controller (option 2). 

10 = IDMA requests have the lowest priority (option 3). 

11 = Reserved. 


ElE—External Interrupt Enable 


Configure this bit as instructed in the download process of a Motorola-supplied RAM 
microcode package. This bit is also used by IDMA channel 1 to enable single-buffer mode, 
as described in Section 16.6.3.11.4 Single-Buffer Burst Fly-By Mode. 


0 = DREQ1 pin cannot interrupt the microcontroller. 
1 = DREQ?1 pin can interrupt the microcontroller. 


SCD—Scheduler Configuration 


Configure this bit as instructed in the download process of a Motorola-supplied RAM 
microcode package. 


O = Normal operation. 
1 = Alternate configuration of the scheduler. 


ERAM—Enable RAM Microcode 


Configure this field as instructed in the download process of a Motorola-supplied RAM 
microcode package. This field is used in conjunction with the ERAM 4K bit in the RMDS 
register to configure the RAM microcode space. 


Table 16-1. RAM Microcode Configurations 


ERAM (RCCR) BIT 0 IN MICROCODE ADDRESSES 
RMDS 








2000-23ff and 2f00-2fff 


2000-21 ff, 2f00-2fff, 3000-37ff, 
and 3a00-3 


2000- et See ae 3000-37ff, 
0-3bff 










2000-27ff, 2e00-2fff, 
3000-37ff, and 3a00-3bff 


a 
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16.2.7 RISC Microcontroller Commands 


To initialize the serial channel or DMA, you can issue a command to the CPM command 
register. The command you issue will ask the communication processor module to perform 
further device-specific functions based on the information in the device’s parameter RAM. 


16.2.7.1 CPM COMMAND REGISTER. The core sets the FLG bit in the 16-bit, 
memory-mapped, read/write CPM command register (CPCR) when it issues a command 
and the communication processor module clears the FLG bit when the command is 
completed. The core is now ready for the next command. Subsequent commands to the 
CPCR can only be given when the FLG bit is clear. When issuing the software reset 
command, the core should also set the FLG bit. 


CPCR 


~ RESERVED --OPCODE CH NUM RESERVED 


(IMMR & OxFFFF0000) + 0x9CO 





RST—Software Reset Command 


This bit is set by the core and cleared by the communication processor module and when 
this command is executed, the RST and FLG bits are cleared within two general system 
clocks. The RISC reset routine is approximately 60 clocks long, but you can start initializing 
the communication processor module immediately after this command is issued. RST is 
useful when the core wants to reset the registers and parameters for all the channels as well 
as the RISC microprocessor and timer tables. However, this bit does not affect the serial 
interface or parallel I/O registers. 


O = No reset is issued. 
1 = Reset is issued. 


Bits 1-3—Reserved 
These bits are reserved and should be set to 0. 


OPCODE—Operation Code 


This field is used in conjunction with the CH_NUM field to define a command sent to the 
CPM. It issues a variety of commands, which are described in Table 16-2. For the same 
operation code, the results may be different, depending on the channel number you select. 
For example, if your operation code is 0101 (GRACEFUL STOP TX) and your channel 
number is set to 0100 (SCC2), then the operation will gracefully stop the transmit on SCC2. 
lf your channel number is set to 0001 (IDMA1), then the operation will gracefully stop the 
transmit on IDMA1. 
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CH_NUM—Channel Number 


This field is set by the core to define the peripheral I/O channel that the command is applied 
to. Some peripherals share channel number encodings if their commands are mutually 
exclusive. See Table 16-2 for more information. | 


Bits 12—14—Reserved 
These bits are reserved and should be set to 0. 


FLG—Command Semaphore Flag 
The bit is set by the core and cleared by the communication processor module. 


0 = The communication processor module is ready to receive a new command. 

1 = The CPCR contains a command that the communication processor module is 
currently processing. The communication processor module clears this bit when 
the command finishes executing or after reset. 
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16.2.7.2 COMMAND DEFINITIONS. The RISC microcontroller requires an opcode and a 

_ channel number to determine which command to issue. These opcodes and their definitions 
are described below. The opcodes and channel numbers that appear in Table 16-2 are 
actually the commands to be issued in the CPCR. 


Table 16-2. RISC Microcontroller Commands 






CHANNEL NUMBER 


opcope| SCC2 USB SMC1 SPI 2c IDMA1 | IDMA2 | DSP1 | DSP2 | TIMER 
(0100) (0000) (1001) OR (0101) (0001) (0001) | (0101) RX TX (0101) 
. SMC2 (1001) | (1101) 
(1101) 
(UART/ 
_ TRANS) . 


0000 INIT INIT INIT INIT INIT INIT 
RX AND TX | RX AND TX | RX AND TX | RX AND TX | RX AND TX | RX AND TX 
PARAMS | PARAMS | PARAMS | PARAMS | PARAMS | PARAMS 
INIT RX INIT RX INIT RX INIT RX INIT RX 
INIT TX INIT TX INIT TX INIT TX INIT TX 
PARAMS | PARAMS | PARAMS PARAMS | PARAMS 
0011 ENTER ENTER ENTER 
HUNT HUNT HUNT 
MODE MODE MODE 
| 100 STOP TX | STOPTX | STOP TX 
0101 | GRACEFUL | GRACEFUL 
STOP TX | STOP TX 






















ARM ARM INIT 
IDMA IDMA DSP 
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The RISC microcontroller commands consist of the following: 


INIT TX AND RX PARAMS—The initialize transmit and receive parameter command 
initializes the transmit and receive parameters in the parameter RAM to the values that 
they had when the communication processor module was last reset. This command is 
especially useful when switching protocols on a serial channel. 


INIT RX PARAMETERS—The initialize receive parameters command initializes the 
receive parameters of the serial channel. 


INIT TX PARAMETERS—The initialize transmit parameters command initializes the 
transmit parameters of the serial channel. 


ENTER HUNT MODE—The enter hunt mode command causes the receiver to stop 
receiving and start looking for a new frame. The exact operation of this command 
depends on the protocol that is used. 


STOP TX—The stop transmission command stops transmitting from this channel as 
soon as the transmit FIFO has been emptied. It should only be used when 
transmissions need to be stopped as quickly as possible. Transmission continues when 
the RESTART TX command is issued. 


GRACEFUL STOP TX—The graceful stop transmission command stops transmitting 
from this channel as soon as the current frame has been fully transmitted from the 
transmit FIFO. Transmission continues when the RESTART TX command is issued 
and the R bit is set in the next transmit buffer descriptor. 


RESTART TX—Once the STOP TX command has been issued, the restart 
transmission command is used to start transmitting again at the current buffer 
descriptor. 


CLOSE RX BD—The close receive buffer descriptor command causes the receiver to 
close the current receive buffer descriptor, which makes the receive buffer available for 
you to manipulate. The next available buffer descriptor is used to continue reception. 
You can use this command to access the data buffer and you won't have to wait until 
the serial communication controller fills it. 


INIT IDMA—The initialize IDMA command initializes the IDMA internal state to the 
value it had at system reset. It is only required when the IDMA autobuffer or buffer 
chaining modes are used. 

ARM IDMA—The arm IDMA command causes the IDMA to open the next buffer 
descriptor in the table. It can be used to reduce the latency of servicing the first IDMA 
request. 

SET TIMER—The set timer command is used to activate, deactivate, or reconfigure the 
16 timers of the RISC timer table. 

SET GROUP ADDRESS—The set group address command sets a hash table bit for 
the Ethernet logical group address recognition function. 

GCI ABORT REQUEST—The GCI abort request command causes the MPC823 
receiver to send an abort request on the A bit of the GCI bus. 
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¢ GCI TIMEOUT—The GCI timeout command causes the MPC823 transmitter to send 
an abort request on the E bit of the GCI bus. 


RESET BCS—The reset block check sequence command is used in BISYNC mode to 
reset the block check sequence calculation. 


e USB—The USB commands have the same opcode. See Section 16.10 Universal 
_ Serial Bus Controller for a more detailed description. 


16.2.7.2.1 CPM Command Register Examples. For example, to perform a complete 
reset of the communication processor module, you should write 0x8001 to the CPCR, which 
also sets the RST and FLG bits. After you issue this command, the CPCR returns a value 
of 0x0000 after two clocks. To execute an ENTER HUNT MODE command to the SCC2, 
write 0x0341 to the CPCR. While this command is executing, the CPCR returns a 0x0341 
value and once it is finished it returns a 0x0340 value, which clears the FLG bit. 


by 4 Note: The worst-case command execution latency is 120 clocks and the typical 
= command execution latency is approximately 40 clocks. 
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16.2.7.3 DUAL-PORT RAM. The communication processor module has 8,192 bytes of 
static RAM that is configured as dual-port memory. Revision 0 of the MPC823 silicon has a 
5K dual-port RAM. A block diagram of the dual-port RAM is illustrated in Figure 16-4. 


DUAL-PORT RAM 







RISC INSTRUCTION 
U BUS ADDRESS 


Fo a ee a 








U-BUS DATA 





RISC INSTRUCTION ADDRESS ADDRESS 


SELECTORS 









RISC DATA ADDRESS RISC DATA 


PARAMETER RAM 
U BUS ADDRESS 






ADDRESS 
SELECTORS 


DATA 
SELECTORS 






RISC DATA ADDRESS 


NOTE: The shaded area indicates the area that is implemented on the silicon. 


Figure 16-4. Dual-Port RAM Block Diagram 


The dual-port RAM can either be accessed by the RISC microcontroller or one of two bus 
masters—the core or the serial DMA channel. When the dual-port RAM is accessed by one 
of these, it is accessed in two clocks. However, when it is accessed by the microcontroller, 
it is accessed in one clock. When simultaneous accesses occur with at least one write 
operation, the microcontroller is delayed by one clock. 
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5 __ OK DPRAM_BASE = (IMMR & OxFFFF0000) + 0x2000 
0 ce if DPRAM_BASE = (IMMR & OxFFFFO000) + 0x2200 
z 
= ra 
= —— 1K DPRAM_BASE = (IMMR & OxFFFFO000) + 0x2400 
ce 
Li) 
—- 2K DPRAM_BASE = (IMMR & OxFFFF0000) + 0x2800 
3K 
DPRAM_BASE = (IMMR & OxFFFFO000) + 0x2E00 
4K DPRAM_BASE = (IMMR & OxFFFFO000) + 0x3000 
5K DPRAM_BASE = (IMMR & OxFFFF0000) + 0x3400 
6K DPRAM_BASE = (IMMR & OxFFFF0000) + 0x3800 
DPRAM_BASE = (IMMR & OxFFFF0000) + 0x3A00 
7K DPRAM_BASE = (IMMR & OxFFFFO000) + 0x3C00 
8k 





Figure 16-5. Dual-Port RAM Memory Map 
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When the dual-port RAM is accessed by the core or SDMA channel, the data and address 
are passed to and from the U-bus. The microcontroller has access to the entire dual-port 
RAM for data fetches and portions of the system RAM for microcode instruction fetches. 


The dual-port RAM is used to complete the following tasks. Any two of them can occur 
simultaneously. 


¢ To store the parameters associated with the USB, SCC2, SMCs, SPI, IC, and IDMAs 
in the 1,024-byte parameter RAM. : 


e To store the buffer descriptors that describe where data is to be received and 
transmitted. 


e To store the data from the serial channels. This is optional because data can also be 
stored in external memory. 


e To store the RAM microcode for the RISC microcontroller. This feature allows Motorola 
to add protocols in the future. 


e To use as an additional scratchpad RAM space for your program. 


Only the content of the parameter and microcode RAM options require the use of fixed 
addresses. The buffer descriptors, buffer data, and scratchpad RAM can be located in the 
internal system RAM or in any unused parameter RAM. For instance, the area that is 
available when a serial channel or sub-block is not being used. When a microcode from 
RAM is executed, certain portions of the system RAM are no longer available. There are 
three possible configurations for microcode area sizes— first 512-byte block with a 256-byte 
extension (RCCR ERAM=01), first 1,024-byte block with 256-byte extension (RCCR 
ERAM=10), or first 2,048-byte block with 512-byte extension (RCCR ERAM=11). The 
remainder of the first 4,096 bytes are available as system RAM. See Table 16-1 for details. 


16.2.7.3.1 Buffer Descriptors. The universal serial bus, serial communication controller, 
serial management controllers, serial peripheral interface, and |?C always use buffer 
descriptors to control data buffers. The table below shows that their buffer descriptor formats 
are all the same. If the IDMA channel is used in buffer chaining or autobuffer mode, it also 
uses buffer descriptors. 


STATUS AND CONTROL 
DATA LENGTH , 
HIGH-ORDER DATA BUFFER POINTER 


LOW-ORDER DATA BUFFER POINTER 





16.2.7.3.2 Parameter RAM. The communication processor module maintains a section of 
dual-port RAM called the parameter RAM. It contains many parameters for a universal serial 
bus, serial communication controller, serial management controller, serial peripheral 
interface, I?C controller, and IDMA channel operation. The parameter RAM structure is 
summarized in Table 16-3. | 
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A definition of the parameter RAM is contained in each protocol subsection that describes 
the device using a parameter RAM. For example, in some locations the Ethernet parameter 
RAM memory map is defined in the same way that the HDLC specific parameter RAM is 
defined. 


Table 16-3. Parameter RAM Memory Map 


| PAGE ADDRESSES | PERIPHERAL | 
1 DPRAM_Base+ 0x1c00 USB 
DPRAM_Base+ Ox1c7f 


_ DPRAM_Base+ 0x1c80 I2C 


DPRAM_Base+ Ox1caf 


DPRAM_Base+ 0x1cb0 MISC 





IMMR + 0x3C00 







DPRAM_Base+ 0x1cbf 
DPRAM_Base+ 0x1cc0 IDMA1 
DPRAM_Base+ Ox1cff 


IMMR + 0x3D00 2 DPRAM_Base+ 0x1d00 SCC2 
DPRAM_Base+ 0x1d7f* 


__DPRAM_Base+ 0x1d80 SPI 


DPRAM_Base+ Ox1daf 
DPRAM_Base+ Oxidb0 Timers 
DPRAM_Base+ 0x1 dbf 
DPRAM_Base+ 0xidc0 IDMA2 
DPRAM_Base+ Ox1dff 


IMMR+0x3E00 | 3 Reserved 
DPRAM_Base+ 0x1e80 SMC1 
DPRAM_Base+ Ox1ebf 
DPRAM_Base+ Ox1tecO DSP1 
DPRAM_Base+ Ox1eff 


IMMR + 0x3F00 4 DPRAM_Base+ 0x1f00 


<a 
a 


NOTE: DPRAM_Base = (IMMR & OxFFFFOOO0) + 0x2000. 
* Ox1da3 for Ethernet. 
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16.2.7.4 THE RISC TIMER TABLES. The RISC microcontroller can have a maximum of 16 
timers that are separate and distinct from the four general-purpose timers and baud rate 
generators of the communication processor module. These timers are ideal for protocols 
that do not require extreme precision, but do need to free the host CPU from scanning the 
software’s timer tables. These timers are clocked from an internal timer that only the 
microcontroller can access. Each pair of timers can be configured as pulse width modulation 
(PWM) channels. The output of the channel is driven on one of the port B pins anda 
maximum of six PWM channels are supported. The following list summarizes the main 
features of the RISC timer tables. 


e Supports a maximum of 16 timers 

e Supports a maximum of six PWM channels 

e Three timer modes—one-shot, restart, and PWM 

e Maskable interrupt on timer expiration 

e Programmable timer resolution as low as 41ms at 25MHz 
e Maximum timeout period of 172sec at 25MHz 

e Continuously updated reference counter 


RISC timer table operations are based on a “tick” in the RISC internal timer that is 
programmed in the RISC controller configuration register (RCCR). The tick is a multiple of 
1,024 general system clocks. The RISC timer tables have the lowest priority of all RISC 
microcontroller operations, so if it is so busy with other tasks that it is unable to service the 
timer during a tick interval, one or more of the timers might not be updated. This behavior 
can be used to estimate the worst-case loading of the microcontroller. The timer tables are 
configured in the RCCR, the timer table parameter RAM, the SET TIMER command that is 
issued to the CPCR, the timer event register, and the timer mask register. 


16.2.7.4.1 RISC Timer Table Parameter RAM Memory Map. Two areas of internal RAM 
are used for the RISC timer tables—RISC timer table parameter RAM and the RISC timer 
table entries—which are shown in Figure 16-6. The RISC timer table parameter RAM area 
begins at the RISC timer base address and is used for the general timer parameters. See 
Table 16-4 for details. 


Note: All references to registers in the parameter RAM table are actually implemented 
in the dual-port RAM area as a memory-based register. 
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DUAL-PORT RAM 












16 RISC 
TIMER TABLE 
ENTRIES 
(UP TO 64 BYTES) 


INDEX POINTER 


TIMER PARAMETER RAM 
IMMR + 3DB0 


TIMERBASE 


TM_BASE 






~ TIMER TABLE 
- PARAMETER RAM 
(14 BYTES) 


Figure 16-6. RISC Timer Table RAM Usage 
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Table 16-4. RISC Timer Table Parameter RAM Memory Map 


[—rooness [wane [worm [_oescnron 


NOTE: You are only responsible for initializing the items in bold. 
TimerBase = (IMMR & OxFFFFOOO0) + Ox3DBO. 

















e TM_BASE—This index pointer contains a 16-bit offset from the beginning of the 
dual-port RAM to the location of your timer table entry. For the timer table entry area, 
you should allocate four bytes for each timer used. If you use all 16 timers, you must 
allocate 64 bytes in the timer table entry area. If you do not use all the timers, the timers 
should always be allocated in ascending order to save space. For example, if you only 
need two timers, then 8 bytes are required for the timer table entry area as long as you 
only enable RISC timers 0 and 1. 4 


Note: The timer table entry area pointed to by the TM_BASE should always be aligned 
to a word boundary that is evenly divisible by four. 


e TM_PTR—This index pointer is used exclusively by the RISC microcontroller to point 
to the next entry to be executed in the timer table. You should not modify this pointer. 
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e R_TMR—Only the RISC microcontroller uses this register to store the mode of the 
timer—one-shot (0) or restart (1). You should not modify this register. Instead, you 
should use the SET TIMER command in the CPCR to control the timer mode. 


Paes te ‘ 
Bee Soe 
4 oe ‘y, 


ee tee 
bee Bt Be i i 
eo 
ye Aa rs “ss 
FE i me : 


TMR15 | TMR14 | TMR13 | TMRi2 ) TMR11 | TMR10 } TMR9 | TMR8 | TMR7 TMR5 TMR3 


Pow Pow [ow [ow [ow [ow [ow [ow fo [ow [ow [ow [ow [aw [av [ow 


(IMMR & OxFFFF0000) + 0x3DB4 eS 





TMRO-15—Timer 0-15 


O= No effect. 
1 = Clears a bit in this register. 


e R_TMV—Only the RISC microcontroller uses this register to determine whether or not 
a timer is currently enabled. If the corresponding timer is enabled, a bit is 1. You should 
not modify this register. You should use the SET TIMER command to enable a timer. 


oe 
Bu iS 
eo eB 

RO 


TMR9 | TMR8 TMR6 } TMR5 | TMR4 |} TMR3 |} TMR2 | TMRI1 


(IMMR & OxFFFFO000) + 0x3DB6 





TMRO—15—Timer 0-15 


0 = No effect. 
1 = Clears a bit in this register. 
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e TM_CMD—This register is used as a parameter location when the SET TIMER 


command is issued. You should write this location prior to issuing the SET TIMER 
command. The bits of this register are defined as follows: 


TM_CMD 













Pv | R [Pw 
ee ee 
R/W | RW | RW RAW a 

pw i rw {Rw RW 


ee 
TIMER PERIOD 
: | (IMMR & OxFFFF0000) + 0x3DBA 


V—Valid 

0 = Disables the timer. 
1 = Enables the timer. 
R—Restart 


0 = One-shot timer operation. 
1 = Automatic timer restart. 











PWM—Pulse-Width Modulation Mode 


0 = Normal mode. 
1 = Pulse-width modulation. 


Bits 3-11—Reserved 
These bits are reserved and should be set to 0. 





TIMER NUMBER i 
This bit is the value from zero to 15 that signifies timer configuration. ——_—— 


tr ENC 


ip 
rn 


TIMER PERIOD 


This bit is the 16-bit timeout value of the timer. The maximum value is 65,536 and is 
encoded as Ox0000. 


e TM_CNT—This register is a tick counter that the microcontroller updates after each tick 
or after the timer table is scanned. It is updated if the microcontroller’s internal timer is 
enabled, regardless of whether any of the 16 timers are enabled, and it can be used to 
track the number of ticks the microcontroller receives and responds to. 


PROCESSOR MODULE — 


z 
© 
ome 
< 
o 
Zz 
=) 
= 
= 
oO 
oO 


16 





~ MOTOROLA : MPC823 USER’S MANUAL 16-23 





DO 
ok= 
Me 
De 
(exe) 
yb. 
~ 
==> 
OC . 
o0= 
os 
oo 
a 





Communication Processor Module 


16.2.7.4.2 RISC Timer Table Entries. The 16 timers are located in the block of memory 
that TM_BASE points to and each timer occupies 4 bytes. The first half-word forms the initial 
value of the timer written when the SET TIMER command is executed. The next half-word 
is the current value of the timer that gets decremented until it reaches zero. You should not 
modify these locations because they should only be used for debugging purposes. 


16.2.7.4.3 The SET TIMER Command. This command is issued to the CPCR and is used 
to enable, disable, and configure the 16 timers in the RISC timer table. The 0x0851 value 
should be written to the CPCR, but before doing that you should set up the TM_CMD value. 


16.2.7.4.4 PWM Mode. Each pair of timers can be used to generate a pulse-width 
modulation waveform on one of the port B pins. A maximum of six channels are supported. 
The first timer (even numbered) is used to control the duty-cycle time of the waveform. In 


_the register above, the TIMER PERIOD entry should be set to the high period of the 


waveform and the PWM and V bits should be set-to 1. The second timer (odd numbered) is 
used to control the cycle time. The TIMER PERIOD entry should be set to the preferred 
cycle time, the PWM bit should be set to zero, and the R and V bits should be set to 1. 
Table 16-5 shows the port B pin assignments for the PWM mode. The respective port B pins 
should be configured as general-purpose outputs in the PBDIR in Section 16.14.6.3 Port B 
Data Direction Register. 


Table 16-5. PWM Channel Pin Assignments 


Not Available 


Not Available 
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16.2.7.5 RISC TIMER EVENT REGISTER. The 16-bit RISC timer event register (RTER) is 
used to report events recognized by the 16 timers and to generate interrupts. However, an 
interrupt is only generated if the RISC timer table bit is set in the CPM interrupt mask 
register. More than one bit can be cleared at a time. 


RTER 


: 
Cinta oe 


a Me 
TMR15 | TMR14 } TMR13 | TMR12 | TMR11 | TMR10 |} TMR9 TMR8 | TMR7 TMR6 TMR5 TMR4 | TMR3 TMR2 TMR1 TMRO 


(IMMR & OxFFFFO000) + 0x9D6 





TMRO-—15—Timer 0-15 


0 = No effect. 
1 = Clears a bit in the register. 


16.2.7.6 RISC TIMER MASK REGISTER. This 16-bit read/write RISC timer mask register 
(RTMR) is used to enable interrupts that can be generated in the RTER. If a bit is sett, it 
enables the corresponding interrupt in the RTER. If a bit is cleared, this register masks the 
corresponding interrupt in the RTER. However, an interrupt is only generated if the R-TT bit 
is set in the CPM interrupt mask register (CIMR), which is described in 

Section 16.15.5.3 CPM Interrupt Mask Register. 


RTMR 


TMR15 | TMR14 | TMR13 | TMR12 | TMR11 | TMR10 | TMR9 | TMR8 | TMR7 |} TMRG | TMRS | TMR4 | TMRS | TMR2 | TMR1 | TMRO 
Gee a ae ea |e | |e 


(IMMR & OxFFFFO000) + 0x90A 





TMRO-15—Timer 0-15 | | ( 2 
O = Masks the corresponding interrupt in the RTER. 
1 = Enables the corresponding interrupt in the RTER. 
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- 16.2.7.7 RISC TIMER INITIALIZATION SEQUENCE EXAMPLE. Follow these steps to 
initialize the RISC timers: 


1. Configure the RCCR to determine the preferred tick interval that will be used for the 
entire timer table. Normally, you can set the TIME bit at this time. However, it can be 
set later if all RISC timers must be synchronized. 


2. Determine the maximum number of timers to be located in the timer table. Configure 
the TM_BASE pointer of the RISC timer table parameter RAM to point to a location in 
the dual-port RAM with 4 x N bytes available, where N is the number of timers. If N is 
less than 16, use timer 0 through timer N—1 to save space. 


3. Clear the TM_CNT counter of the RISC timer table parameter RAM to show how many 
ticks have elapsed since the RISC internal timer was enabled (optional). 


4. Clear the RTER, if it is not already cleared. A one clears this register. 
5. Configure the RTMR to enable the timers that need to generate interrupts. 


6. Set the R-TT bit in the CIMR to generate interrupts to the system. Make sure the CPM 
interrupt controller is properly initialized. 


7. Configure the TM_CMD register of the RISC timer table parameter RAM. At this point, 
determine whether a timer is to be enabled or disabled, one-shot or restart, and what 
its timeout period should be. If the timer is being disabled, all eave eels besides the 
timer number are ignored. 


8. Issue the SET TIMER command by writing 0x0851 to the CPCR. 
9. Repeat steps 7 and 8 for each timer to be enabled or disabled. 


As an example, the following sequence demonstrates how the RISC timer 0 is initialized to 
generate an interrupt approximately every second using a 25MHz general system clock: 


1. Write 111111 to the TIMEP field of the RCCR to generate the slowest clock. This value 
generates a tick every 65,536 clocks, which is every 2.6 milliseconds at 25MHz. 


2. Configure the TM_BASE pointer of the RISC timer table parameter RAM to point to a 
location in the dual-port RAM with 4 bytes available. Assuming that the beginning of 
dual-port RAM is available, write OxO000 to TM_BASE. 


3. Write 0x0000 to the TM_CNT counter of the RISC timer table parameter RAM to see 
how many ticks have elapsed since the RISC internal timer was enabled (optional). 


4. Write OxFFFF to the RTER to clear any previous events. 
5. Write 0x0001 to the RTMR to enable RISC timer 0 to generate an interrupt. 


6. Write 0x00020000 to the CPM interrupt mask register so the RISC timers will generate 
a system interrupt. Initialize the CPM interrupt configuration register. 


7. Write OxCOOOOEEG to the TM_CMD register of the RISC timer table parameter RAM. 
This enables RISC timer 0 to timeout after 3,814 (decimal) ticks. The timer 
automatically restarts after it times out. 


8. Write 0x0851 to the CPCR to issue the SET TIMER command. 
9. Set the TIME bit in the RCCR to operate the RISC timer. 
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16.2.7.8 RISC TIMER INTERRUPT HANDLING EXAMPLE. The following sequence 
shows what is normally written in an interrupt handler for the RISC timer tables: 


1. Once an interrupt occurs, read the RTER to see which timers have caused interrupts. 
The RISC timer event bits are usually cleared by this time. 


_ 2. Issue any additional SET TIMER commands now or later, whichever you prefer. You 
do not have to do anything if the timer is automatically being restarted for a repetitive 
interrupt. 


3. Clear the R-TT bit in the CPM interrupt status register. 
4. Execute the rfi instruction. 


16.2.7.9 RISC TIMER TABLE ALGORITHM. The RISC microcontroller scans the timer 
table once every tick. For each valid timer in the table, the microcontroller decrements the 
count and checks for a timeout and if no timeout occurs, it moves to the next timer. Ifa 
timeout does occur, the microcontroller sets the corresponding event bit in the RISC timer 
event register. Then it checks to see if the timer needs to be restarted and if it does, it leaves 
the R_TMV register and resets the current count to the initial count. Otherwise, it clears the 
R_TMV register. Once the timer table is scanned, the microcontroller updates the TM_CNT 
value in the RISC timer table parameter RAM and stops working on the timer tables until the 
next tick. If a SET TIMER command is issued, the microcontroller makes the appropriate 
modifications to the timer table and parameter RAM, but does not scan the timer table until 
the next tick of the internal timer. If you modify the RISC timer table, execute the SET TIMER 
command to synchronize the timers so that the microcontroller will operate properly. 


16.2.7.10 USING THE TIMERS TO TRACK MICROCONTROLLER LOADING. The 
following sequence of steps is a method for using the 16 timers to determine if the 
microcontroller ever exceeds the 96% utilization level during a tick interval. Removing the 
timers adds a 4% margin to the microcontroller’s utilization level, but an aggressive user can 
use this technique to push the microcontroller performance to its limit. You should use the 
standard initialization sequence, but incorporate the following steps: 


1. Program the tick of the RISC microcontroller timers to be 1,024 x 16 = 16,384. 
2. Disable microcontroller timer interrupts, as required. 


3. Using the SET TIMER command, initialize all 16 RISC microcontroller timers to have 
a timer period of Ox0000, which equals 65,536. 


4. Program one of the four general-purpose timers to increment once every tick. The 
general-purpose timer should be free-running and have a timeout of 65,536. 


5. After a few hours of operation, compare the general-purpose timer to the current count 
of RISC microcontroller timer 15 and if the difference between them exceeds two ticks, 
the microcontroller has, during some tick interval, exceeded the 96% utilization level. 


Note: The general-purpose timers are up-counters, but the RISC microcontroller timers 
are down-counters. You should take this under consideration when comparing 
timer counts. 
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16.3 DIGITAL SIGNAL PROCESSING 


Many embedded control applications require DSP-style algorithm implementations, such as 
finite impulse response (FIR) filters with or without adaptive equalization, data compression, 
and scrambling. These are written in software on the MPC823 and do not require your 
system to have a separate DSP processor, which would cost you more and consume more 
power. The communication processor module provides the additional power you need for 
those applications. ; | 


The RISC microcontroller’s instruction set (described in Appendix B MPC823 Instruction 
Set) supports high-performance multiply and accumulate (MAC) operation as well as 

special addressing modes that are essential to efficient DSP algorithm implementation. The 
RISC microcontroller runs concurrently with the core and increases the core’s bandwicth left 
for other system tasks. The system can take advantage of this increased core bandwidth by 


lowering the system clock frequency and voltage, which decreases the amount of power that 


is consumed. 


_ 16.3.1 Features 


The following list summarizes the features of MPC823 DSP: 


© 16 x 16-bit multiply and accumulate 
¢ Load/store with automatic post increment/decrement 


¢ DSP routine library provides 11 basic building blocks for implementation of V.34bis 
and 56K 


16.3.2 DSP Operation 


There are three layers to DSP functionality—hardware, firmware, and software. You only 
need to construct the software layer to generate an application. | 


FUNCTION DESCRIPTOR CHAIN IN EXTERNAL 
MEMORY DEFINES THE SEQUENCE AND DATA 
Ere FLOW OF THE DSP FUNCTIONS 
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16.3.2.1 HARDWARE. The RISC microcontroller’s hardware contains special DSP 
processing units, such as a multiplier and accumulator that is capable of handling real or 
complex numbers, and an address generator that can access cyclic buffer structures in 
dual-port RAM. 


16.3.2.2 SOFTWARE. Your software interfaces to the DSP via the function descriptor that 
is described in system memory. The function descriptor defines the sequence and data flow 
of your DSP task. 


16.3.2.3 FIRMWARE. The RISC microcontroller’s firmware is a set of DSP functions that 
have been compiled to form a library of basic building blocks and each function within the 
library is implemented by a microcode routine stored in the internal ROM. In addition, a 
software interface is defined that enables parameters to be passed between the core and 
communication processor module. Several functions can be chained together to reduce 
software intervention and interrupt rates, assuming that all data structures reside in the 
dual-port RAM. Table 16-6 lists the DSP functions that are included in the library. 


Table 16-6. DSP Functions 


[ina [ 000; | feat Res! | fea! | __Decnaton,FXinipoaion 
[rine | enor | connie | Fest | conpex | TAF iter 
[rine [ core [Fest | cormier | compex | 
Tam [ oor [rea [Fest | fea | —a rte —— 
[woo | —o1o00 [connie | Ganvior | fealGonmiex | ___TXWodiston 
eS ae EC Update, Equalizer Update (T/2, T/3) 
ee ee 
a ee 












LMS1 01010 P| 
| umsz 01011 P| 
WADD 01100 | Real | 


16.3.3 Programming the DSP Functions 


Similar to the SCC2 buffer descriptor, a function descriptor (FD), is used to specify the DSP 
function and pass the parameters. A table of such descriptors forms a circular queue with a 
programmable length. The descriptors are stored in external memory. There are two 
function descriptor tables (also referred to as chains)—one for the transmitter and one for 
the receiver. The core prepares a chain of function descriptors in the system memory anda 
special host command notifies the RISC microcontroller when to execute the chain. A 
maskable interrupt is generated once the chain is completed. As shown in Figure 16-8, the 
pointer to the transmit (TX) chain must be written into the FDBASE field of the DSP2 
parameter RAM and the pointer to the receive (RX) chain must be written into DSP1. 
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DUAL-PORT MEMORY : SYSTEM MEMORY 


Ae ey ee i ee Oe ee aa ee es a Fea Sie gs Bee ee” Ena ate wrayer nea FE 


| | RECEIVE FD CHAIN 






DSP 
DSP2 


RX CHAIN BASE 
TX CHAIN BASE 







INPUT, OUTPUT, AND COEFFICIENT 
BUFFERS 






TRANSMIT FD CHAIN 





Figure 16-8. DSP Function Descriptor Operation 


16.3.3.1 DATA REPRESENTATION. The inputs, coefficients, and outputs are represented 
by 16-bit, fixed-point, 2’s complement numbers. A real number is represented by a single 
16-bit half-word, as shown in Figure 16-8. Its value is between -1 (Ox8000) to +1 (Ox7FFF 
and you must scale your data to fit this range. A complex number is represented by a pair 
of 16-bit half-words—one word for the imaginary component and one for the real component 
as shown in Figure 16-8. They must be scaled to fit in the -1 and +1 range. 


REAL FRACTION 


REAL FRACTION 
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16.3.3.2 MODULO ADDRESSING. The input and output buffers are circular within a 
certain programmable size that must be a multiple of 2“. The base address of the circular 
buffer must be aligned on its natural size boundary. For example, if your input buffer size is 
128 bytes, your base address must be aligned on a 128-byte boundary. In other words, the 
lower boundary (base address) of a circular buffer containing modulus (M) bytes must have 
zeros in the k LSBs of the base address, where 2* > M, and therefore must be a multiple of 
2k The upper boundary is the lower boundary, plus the size minus one (base addiess + 
M-1). Once M is chosen, a sequential series of memory blocks (each of length 2) is created 
where these circular buffer can be located. If M < 2, there is a 2"-M space between the 
sequential M-sized circular buffers and M should be a multiple of four. See Figure 16-9 for 
details. 


UPPER BOUNDARY 






ADDRESS 


- OIRCULAR 
POINTER : 


M = MODULUS 


LOWER BOUNDARY 


Figure 16-9. Circular Buffer 


16.3.3.2.1 DSP Function Descriptors. Each function descriptor is composed of eight 
16-bit half-words. The first half-word contains the function opcode as well as status and 
control bits and the other half-words contain the function’s parameter packet. Each function 
has its own parameter packet. 


Pwo | RESERVED OPCODE 
PARAMETER 1 





PARAMETER 7 


S—STOP 


0= Do not stop after executing this function descriptor. 
= Stop after executing this function descriptor. 


Bits 1 and 4—10—Reserved 
These bits are reserved and should be set to 0. 
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W—Wrap (Final Function Descriptor in Table) 


0 = This is not the last function descriptor in the function descriptor table. 

1 = This is the last function descriptor in the function descriptor table. After this buffer 
has been used, the communication processor module processes the first function 
descriptor that the FDBASE index pointer points to in the table. The number of 
function descriptors in this table is programmable and determined only by the W bit 
and the overall space constraints of the memory. 


I—Interrupt 


O = No interrupt is generated after this function is processed. 
1 = A maskable interrupt is generated after this function is processed. 


OPCODE—Function Operation Code 


This field specifies the function that should be executed. Some of these bits are reserved so 
they can be expanded by tapping into RAM and executing a routine. See Table 16-6 for 
more information. 


16.3.3.2.2 DSP Parameter RAM Memory Map. Each section in the dual-port RAM is 
associated with each DSP chain and can be used for parameter storage or as a Scratchpad. 
The FDBASE index pointer defines the place in system memory for the function descriptor 
chain to start. It should be 16-byte aligned. Also, the FDBASE index pointer should be 
initialized before the INIT_DSP command is issued. See Table 16-7 for DSP parameter 
RAM memory map details. 
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Table 16-7. DSP Parameter RAM Memory Map 


ADDRESS | NAME | WIDTH DESCRIPTION 
DSP Base + 0x00 FDBASE Function Descriptor Table Base Address 
DSP Base + 0x04 FD_PTR Function Descriptor Pointer 







[sense | Hat 


DSP Base + Ox1E YPTR Half-word Current Function Descriptor Pointer to Output Buffer Pointer 





DSP Base + 0x20 pM Half-word Current Function Descriptor Sample Buffer Size-1 
DSP Base + 0x22 pF Half-word Current Function Descriptor Sample Buffer Pointer 
Ee Half-word Current Function Descriptor Output Buffer Size-1 


DSP Base + 0x24} N 





DSP Base + 0x26 po Half-word Current Function Descriptor Output Buffer Pointer 
DSP Base + 0x28 Half-word Current Function Descriptor Coefficient Buffer Size-1 
DSP Base + 2A | Half-word ~ Current Function Descriptor Coefficient Buffer Pointer 


NOTE: You are only responsible for initializing the items in bold. | 
DSP1 Base = (IMMR & OxFFFF0000) + 0x3ECO and DSP2 base = (IMMR & OxFFFFO000) + Ox3FCO. 





FDBASE—Function Descriptor Table Base Address 


This index pointer defines the location in system memory where the function descriptor 
starts. However, you must initialize it. 


FD_PTR—Function Descriptor Pointer 


This pointer points to the current function descriptor address. It is only used by the RISC 
microcontroller, so you do not need to modify it in any way. 


DSTATE—Current State 


This bit defines the internal state of the RISC microcontroller. It is only used by the RISC 
microcontroller, so you do not need to modify it in any way. 


DSTATUS—Current Function Descriptor Status 


This bit defines the current status of the current function descriptor. It is only used by the 
RISC microcontroller, so you do not need to modify it in any way. 


I—Current Function Descriptor Number of Iterations 
This bit is only used by the RISC microcontroller, so you do not need to modify it in any way. 
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TAP—Current Function Descriptor Number of Taps 
The bit is only used by the RISC microcontroller, so you do not need to modify it in any way. 


CBASE—Current Function Descriptor Cbase 


The bit defines the current function descriptor base address of the coefficients. It is only 
used by the RISC microcontroller, so you do not need to modify it in any way. 


XPTR—Current Function Descriptor Pointer to Sample Pointer 
The bit is only used by the RISC microcontroller, so you do not need to modify it in any way. 


YPTR—Current Function Descriptor Pointer to Output Buffer Pointer 
The bit is only used by the RISC microcontroller, so you do not need to modify it in any way. 


M—Current Function Descriptor Sample Buffer Size-1 
The bit is only used by the RISC microcontroller, so you do not need to modify it in any way. 


N—Current Function Descriptor Output Buffer Size-1 | 
The bit is only used by the RISC microcontroller, so you do not need to modify it in any way. 


K—Current Function Descriptor Coefficient Buffer Size-1 
The bit is only used by the RISC microcontroller, so you do not need to modify it in any way. 


16.3.3.2.3 DSP Commands. The following commands are issued to the CPM command 
register (CPCR) and they are defined in detail in Table 16-6. 


¢ INIT DSP CHAIN—Deactivates the corresponding chain. The function descriptor 
pointer is initialized to the starting address provided in the function descriptor table. 


¢ START DSP CHAIN—Activates the corresponding chain. 
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16.3.3.3 DSP EVENT REGISTER. For DSP interrupts, the memory-mapped SDMA status 
register (SDSR) is used to generate maskable interrupts to the core. An interrupt is set when 
the function finishes executing if the | bit is set in the function descriptor. There are two 
interrupt events—DSP1 and DSP2—that are each associated with a corresponding chain. 
A bit is reset by writing a 1 (writing a zero has no effect) and more than one bit can be reset 
at a time. 


SDSR 





(IMMR & OxFFFFO000) + 0x908 


SBER—SDMA Channel Bus Error (SDMA function) 


When set, this bit indicates that an error caused the SDMA channel to terminated during a 
read or write cycle. The SDMA bus error address can be read from the SDMA address 
register, as shown in Section 16.5.2.4 SDMA Address Register. 


Bits 1-5—Reserved 
These bits are reserved and should be set to 0. 


DSP2—DSP Chain 2 Transmitter Interrupt (DSP function) 


This bit is set when the chain 2 function finishes execuung: However, the | bit must be set in 
the function descriptor. 


DSPi—DSP Chain 1 Receiver Interrupt (DSP function) 


This bit is set when the chain 1 function finishes executing. However, the | bit must be set in 
the function descriptor. 
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16.3.3.4 DSP MASK REGISTER. The 8-bit read/write SDMA mask register (SDMR) is 
used to mask the DSP interrupts and has the same bit format as the SDSR. If a bit in the 
SDMR is a 1, the corresponding interrupt in the SDSR is enabled and if itis zero, the 
corresponding interrupt is masked. This register is cleared by reset. 


SDMR 












DSP1 


OO 
i SN I AA 


SBER—SDMA Channel Bus Error (SDMA function) 


0 = Disable the interrupt. 
1 = Enable the interrupt. 


Bits 1-5>—Reserved 
These bits are reserved and should be set to 0. 


DSP1—DSP Chain 1 Receiver Interrupt (DSP function) 


0 = Disable the DSP chain 1 interrupt. 
1 = Enable the DSP chain 1 interrupt. 


DSP2—DSP Chain 2 Transmitter Interrupt (DSP function) 


0 = Disable the DSP chain 2 interrupt. 
1 = Enable the DSP chain 2 interrupt. 
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16.3.3.5 DSP IMPLEMENTATION. There are basically two ways to implement a DSP 
task—run C code on the core or use the communication processor module functions. 
Figure 16-10 illustrates an example section of a V.32 modem’s transmit (TX) data pump 
flow. The TX filter is composed of three FIR2 subfilters. — 


1 INPUT / BAUD 3 OUTPUTS / BAUD 3 OUTPUTS / BAUD 


MODULATION 






TX FILTER 


COS WT, SIN WT 


Figure 16-10. DSP Implementation Example 


To implement this DSP task with C code on the core, it takes 476 core instructions (371 for 
the filter and 105 for the modulation) to execute the code. Repeating that 2,400 times a 
second consumes 1.14MIPS (476 x 2,400) of the core. To implement a task using the CPM 
functions, the software builds a static function descriptor structure composed of two chained 
functions—a FIR2 and a MOD. The core activates the RISC microcontroller to execute those 
functions by sending a single write to the CPM command register. Using an interrupt, the 
communication processor module then signals that the process has completed. The 
communication processor module executes the functions twice as efficiently as the core, 
which results in 0.55 CPM MIPS and very few core cycles. | 


The TX filter is implemented by executing three subfilters each time a new sample is 
received. This is accomplished by invoking FIR2 with a three-iteration count and 
autoincrement of the input sample pointer when the function is completed. FIR2 writes the 
three results into the output buffer, which is also the modulation input buffer. Modulation is 
accomplished by invoking MOD with a three-iteration count. The input pointer is 
autoincremented with each iteration. 
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16.3.3.5.1 DSP Programming Example (Core Only). 


void tx_filter () 
{ 
S16 *coefr 
S16 *samplr, *sampli 
S16 *coefend; 
S32 filtoutr, filtouti; 
U8 subcount, sampleindex; 
extern S16 mult(S16 pl, S16 p2); /* in-line invocation */ 


coefr=txfiltcoef_str; 
coefend=txfiltcoef_end; 
samplr=&txfiltdly [REAL] [txfiltptr]; 
sampli=&txfiltdly [IMAG] [txfiltptr]; 
sampleindex=0; 
while (coefr<coefend) { 
filtoutr=filtouti=0; 
subcount=0; 
while (subcount<TXSUBFILTLEN) { 
filtoutr+=mult(*coefr, *samplr--); 
filtouti+=mult (*coefr++, *sampli--); 
} 
samplr=&txfiltdly [REAL] [txfiltptr]; 
sampli=&txfiltdly [IMAG] [txfiltptr]; 
modbuff [REAL] [sampleindex]= filtoutr ; 
modbuff [IMAG] [sampleindex++]= filtouti; 


} 
} 
void modulator () 
{ 
U8 i; 
S32..termrnd; , 
extern S16 mult(S16 pl, S16 p2); /* in-line invocation */ 
i=0; 
as + while (i1<SAMPLE_PER_T) { 
go, sigout[i]= mult(sn1800[REAL] [cosindx], modbuf[REAL][i]) - 
ie mult (sni800 [IMAG] [cosindx], modbuf [IMAG] [i]); 
| cosindx++; 
1£ (cosindx==SIN1800TBL_LEN) cosindx=0; 
1++; 
} 
void main () 
{ 
* 
VO 
= Ke} * 
or= 
m= tx_filter(); 
oa modulator () ; 
O92 , 
ae 
25 i 
os 
s] 
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= 
mi 





16-38 _ MPC823 USER’S MANUAL MOTOROLA 


Communication Processor Module 


16.3.3.5.2 DSP Programming Example (Core and CPM). Figure 16-11 illustrates how 
the data buffer and function descriptor data is organized in system memory and dual-port 
RAM. The function descriptor resides in system memory and all input, ouput, coefficient data 
must reside in dual-port RAM. The transmit and modulation FD chain can reside in either 
system memory or dual-port RAM. 


DUAL-PORT RAM SYSTEM MEMORY 
TX FILTER FD 


OPCODE = FIR2 

# OF ITTERATIONS 
# OF TAPS 
COEFF BASE 
IN BUFFER SIZE 
XYPTR 
INPUT POINTER 

OUTPUT POINTER OUT BUFFER SIZE 


MODULATION FD 
MOD TABLE PTR 
| OPCODE =MOD 
| # OF ITERATIONS 
| MOD TABLE SIZE | 
MPTR 
IN BUFFER SIZE 
XYPTR = 
INPUT POINTER - 


_ reorponten OUT BUFFER SIZE 3 


Figure 16-11. Core and CPM Implementation 
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/* Buffer Descriptors */ 
typedef struct dsp_fd { 
unsigned short status; 
unsigned short parameter[7]; 


} DSP_FD; 
#define WRAP 0x2000 — /* wrap bit */ 


#define INTR 0x1000 /* interrupt on completion */ 


/* define for function opcodes */ 
#define FIR_2 Ox0102: /* FIR2 £f£i liter */ 
#define MOD | Ox0008 /* Modulation function opcode */ 


/* Initialize a static fd table for 2 functions */ 
DSP_FD filters[2]= { 
{ FIR_2,P11,P12, , P17} 
,{(WRAP | INTR | MOD) ,P21,P22, , P27} 
a: 


void main() 
{ 
/* Setup FD chain pointer */ 
DSP2_Base. Fdbase = filters; 
* 
/* issue command to CPM to start processing the fd chain */ 
issue_command( START_FD ); 


* 
* 


* 


} 


16.3.4 DSP On-Chip Library Functions 


The DSP library is an easy way to implement DSP functions. It consists of the following 


functions: 
_¢ FIR1—Finite impulse response 1 
a ¢ FIR2—Finite impulse response 2 
———" e FIR38—Finite impulse response 3 


¢ FIR5—Finite impulse response 5 
e FIR6—Finite impulse response 6 
e |IR—Infinite impulse response 

¢ MOD—Modulation 

¢ DEMOD—Demodulation 

e LMSi—Least mean squared 1 

e LMS2—Least mean squared 2 

e WADD—Weighted vector addition 
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16.3.4.1 FIR1I-REAL C, REAL X, AND REAL Y. The FIR1 function implements a basic 
FIR filter with k real coefficients, real input samples, and real output. The input data is ina 
circular buffer with size M+1 and the output data is in a circular buffer with size N+1. 






Yin) =} C(p)X(n-p) 
p=0 


Figure 16-12. FIR1 Implementation Example 


16.3.4.1.1 Coefficients and Sample Data Buffers. The coefficients vector occupies k 
16-bit half-words in memory and C(O) is stored in the first location. The sample input buffer 
is a cyclic buffer containing M+1 bytes. Each sample is a 16-bit word and the new sample is 
stored in the address that follows the previous sample. The output buffer is a cyclic buffer 
that contains N+1 bytes. Each output is a 16-bit half-word and the new output is stored in 
the address that follows the previous output. 











2K bytes | M+ 1 bytes N + 1 bytes 
Figure 16-13. FIR1 Coefficients and Sample Data Buffers 
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16.3.4.1.2 FIR1 Function ab eid The FIR1 function descriptor bit table is described 
below. 


RESERVED 





The first half-word is composed of the following bits: 


S—STOP 


0 = Do not stop after executing this function descriptor. 
= Stop after executing this function descriptor. 


Bits 1, 4, and 9-10—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Function Descriptor in Table) 


0 = This is not the last function descriptor in the function descriptor table. 

1 = This is the last function descriptor in the function descriptor table. After this buffer 
has been used, the CPM processes the first function descriptor that the FDBASE 
index pointer points to in the table. The number of function descriptors in this table 
are programmable and determined penly by the W bit and overall space constraints 
of the memory. 


I—Interrupt 


0 = No interrupt is generated after this function is processed. 
1 = A maskable interrupt is generated after this function is processed. 


[ALL— Auto-Increment X For All Iterations 


O= The X (input) data pointer is incremented (Modulo M+1) by the number of samples 
specified in the INDEX field after the last iteration. | 

1 = The X data pointer is incremented (Modulo M+1) by the number of samples 
specified in the INDEX field after each iteration. © 
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INDEX— Auto-Increment Index 


00 = The X (input) pointer is not incremented. 

01 = The X (input) pointer is incremented by one sample. | 
10 = The X (input) pointer is incremented by two samples. | 
11 = The X (input) pointer is incremented by three samples. | 


PC— Preset Coefficients Pointer 


0= The coefficients pointer is not preset after each iteration. 
1 = The coefficients pointer is preset after each iteration to the CBASE pointer. 


OPCODE—Function Operation Code 
This field specifies the function to be executed. See Table 16-6 to get the value for this field. 


16.3.4.1.3 FIR1 Parameter Packet. The FIR1 parameter packet is composed of seven 
16-bit half-words and described in the following table. 


Table 16-8. FIR1 Parameter Packet 


Taconess [wwe] CmeSRTON 
Tratwoat || [Nmberoiteaions 
Half-word 3 Filter Coefficients Vector Base Address Pointer 


Half-word5 | XYPTR Pointer to a structure composed of the input sample data pointer and the output 
buffer pointer 


Half-word 6 Output Buffer Size-1. The minimum output buffer size is 4 (2 outputs) 


16.3.4.1.4 Application Example. The FIR1 is used in decimation and RX interpolation. For 
example, the following function descriptor structure can be used to implement a 2 to 1 
decimation. ? 
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16.3.4.2 FIR2—REAL C, COMPLEX X, AND COMPLEX Y. The FIR2 function implements 
a basic FIR filter with k real coefficients, complex input samples, and complex output. The 
input data is in a circular buffer with size M+1. and the output data is in a circular buffer with 


size N+1. | | | 
X(N) Y(N) 
~ {COMPLEX} {COMPLEX} 
k—1 | 
Yn) = >) C(p)X(n-p) 
p=0 





Figure 16-14. FIR2 Implementation Example 


16.3.4.2.1 Coefficients and Sample Data Buffers. The coefficients vector occupies k 
16-bit half-words in memory and C(0) is stored in the first location. The sample input buffer 
is acyclic buffer that contains M+1 bytes and each input sample is two 16-bit half-words (real 
and imaginary components). The new sample is stored in the address that follows the 
previous sample. The output buffer is a cyclic buffer containing N+1 bytes. Each output is 
two 16-bit half-words (real and imaginary components). The new output is stored in the - 
address that follows the previous output. 
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OUTPUT 





COEFFICIENTS 


INPUT SAMPLES 


















imag{x(n-1)} 
real{x(n-1)} 


imag{x(n)} 
real{x(n)} 


imag{Y(n-2 
real{Y(n-2) 











)} 
} 











imag{Y(n-1 
real{Y(n-1) 


imag{Y(n)} 
real{Y(n)} 


2K bytes | M+ 1 bytes N + 1 bytes 
Figure 16-15. FIR2 Coefficients and Sample Data Buffers 






)} 
} 


16.3.4.2.2 FIR2 Function Descriptor. The FIR2 function descriptor bit table is described 
below. 













foo Ae 
SS F: 3s = : Be ‘ 
Fe 2 ae seace esa: = 4 sak Sas = <:. 
3 


RES|IALL| INDEX | PC | RES | OPCODE 
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CBASE 





XYPTR 
RESERVED 









The first half-word is composed of the following bits: = 
=O 

S—STOP = 
0 = Do not stop after executing this function descriptor. 22 

1 = Stop after executing this function descriptor. = 

; Oa 
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Bits 1, 4, 9, and 10—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Function Descriptor in Table) 


0 = This is not the last function descriptor in the function descriptor table. 

1 = This is the last function descriptor in the function descriptor table. After this buffer 
has been used, the CPM processes the first function descriptor that the FDBASE 
index pointer points to in the table. The number of function descriptors in this table 
are programmable and determined ony by the W bit and overall space constraints 
of the memory. 


I—Interrupt — 


0 = No interrupt is generated after this function is processed. 
1 = A maskable interrupt is generated after this function is processed. 


|[ALL— Auto-Increment X For All Iterations 


O= The X (input) data pointer is incremented (Modulo M+1) by the number of samples 
specified in the INDEX field after the last iteration. 

1 = The X data pointer is incremented (Modulo M+1) by the number of samples 
specified in the INDEX field after each iteration. 


INDEX— Auto-Increment Index 


00 = The X (input) pointer is not incremented. 

01 = The X (input) pointer is incremented by one sample. 
10 = The X (input) pointer is incremented by two samples. 
11 = The X (input) pointer is incremented by three samples. 


PC— Preset Coefficients Pointer 


0= The coefficients pointer is not preset after each iteration. 
1 = The coefficients pointer is preset after each iteration to CBASE sulnieh: 


OPCODE—Function Operation Code | 
This field specifies the function to be executed. See Table 16-6 to get the value for this field. 
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16.3.4.2.3 FIR2 Parameter Packet. The FIR2 parameter packet is composed of seven 
16-bit half-words and described in the table below. 


Table 16-9. FIR2 Parameter Packet 


Half-word 1 )t | Number of Iterations. . 


Half-word 2 Number of TAPs-1. | 


Half-word 3 CBASE Filter Coefficients Vector Base Address Pointer 


Half-word 4 Samples Buffer Size-1. The minimum sample buffer size is 8 (4 samples) 


Half-word 5 XYPTR Pointer to a structure composed of the input sample data pointer and the output 


buffer pointer 






Half-word 6 Output Buffer Size-1. The minimum output buffer size is 8 (2 outputs) 


Half-word 7 Reserved 








16.3.4.2.4 Application Example. The FIR2 function is used in the TX and RX filters. For 
example, the following function descriptor structure can be used to implement the TX filter. 


l=3 (THREE ITERATIONS) 
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16.3.4.3 FIR3S-COMPLEX C, COMPLEX X, AND REAL/COMPLEX Y. The FIR3 function 
implements a basic FIR filter with k complex coefficients, complex input samples, and real 
or complex output. The input data is in a circular buffer with size M+1 and the output data is 
in a circular buffer with size N+1. 





C(0) 
~ {COMPLEX} 
X(N) p>  Y(N) 
{COMPLEX} (REAL OR COMPLEX} 
k—1 
Y(n) = Real » C(p)X(n—p) 
p =0 
k—1 
OR Yin) = >) C(p)X(n-p) 
p=0 


Figure 16-16. FIR2 Implementation Example 
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16.3.4.3.1 Coefficients and Sample Data Buffers. The coefficients vector occupies k 

pairs of 16-bit half-words (real and imaginary components) in memory and C(0) is stored in 
the first location. The sample input buffer is a cyclic buffer containing M+1 bytes and each 
input sample is two 16-bit half-words (real and imaginary components). The new sample is 
stored in the address that follows the previous sample. The output buffer is a cyclic buffer 


that contains N+1 bytes and each output is two 16-bit half-words (real and imaginary 
components). The new output is stored in the address that follows the previous output. 





COEFFICIENTS 


1 
1) 







imag{C(k-1)} 

















INPUT SAMPLES 
imag {x(n-k+1)} 
real {x(n-k+1)} 


imag {x(n-2)} 










REAL OUTPUT 
(X=0) 





real {Y(n-K+1)} 
real {Y(n-2)} 
real {Y(n-1)} 
yb 


COMPLEX OUTPUT 
(X=1) 









imag{Y(n-k+1)} 
real{Y(n-k+1)} 


imag{Y(n-2)} 
real{Y(n-2)} 
imag{Y(n-1)} 
real{Y(n-1)} 









imag{Y(n)} 
real{Y(n)} 


real{x(n)} | 







N+ 1 bytes 


2K bytes M+ 1 bytes 


N +1 bytes 
Figure 16-17. FIR3 Coefficients and Sample Data Buffers 


16.3.4.3.2 FIR3 Function Descriptor. The FIRS function descriptor bit table is described 
below. a | 
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The first half-word is composed of the following bits: 


S—STOP 


O= Do not stop after executing this function descriptor. 
1 = Stop after executing this function descriptor. 


Bits 1,9, and 10—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Function Descriptor in Table) 


0= This is not the last function descriptor in the function descriptor table. 

1 = This is the last function descriptor in the function descriptor table. After this buffer 
has been used, the CPM processes the first function descriptor that the FDBASE 
index pointer points to in the table. The number of function descriptors in this table 
are programmable and determined only by the W bit and overall space constraints 
of the memory. 


I—Interrupt 


0 = No interrupt is generated after this function is processed. 
1 = A maskable interrupt is generated after this function is processed. 


Z— Complex Output 


O = Only the real component of the result is written to the output buffer. 
1 = The real and imaginary parts of the result are written to the output buffer. 


|[ALL— Auto-Increment X For All Iterations 


O= The X (input) data pointer is incremented (Modulo M+1) by the number of samples 
specified in the INDEX field after the last iteration. 

1 = The X data pointer is incremented (Modulo M+1) by the number of samples 
specified in the INDEX field after each iteration. 


INDEX— Auto-Increment Index 


00 = The X (input) pointer is not incremented. 

01 = The X (input) pointer is incremented by one sample. 
10 = The X (input) pointer is incremented by two samples. 
11= The X (input) pointer is incremented by three samples. 


PC— Preset Coefficients Pointer 


0 = The coefficients pointer is not preset after each iteration. 
1 = The coefficients pointer is preset after each iteration to the CBASE pointer. 


OPCODE—Function Operation Code 
This field specifies the function to be executed. See Table 16-6 to get the value for this field. 
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16.3.4.3.3 FIRS Parameter Packet. The FIR3 parameter packet is composed of seven 
16-bit half-words and described in the table below. 


Table 16-10. FIR3 Parameter Packet 


Half-word 1 a a Number of Iterations 









Half-word 2 K Number of TAPs-1 
Half-word 3 CBASE Filter Coefficients Vector Base Address Pointer 
Half-word 4 Samples Buffer Size-1. The minimum sample buffer size is 8 (2 samples). 


Half-word 5 XYPTR Pointer to a structure composed of the input sample data pointer and the output 
buffer pointer 


Half-word 6 Output Buffer Size-1. The minimum output buffer size for x=1 is 8 (2 outputs). The 
minimum output buffer size for x=0 is 4 (2 outputs). 


16.3.4.3.4 Application Example. The FIR3 with the real output is used in echo 
cancellation and the one with the complex output is used in the equalizer. 
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16.3.4.4 FIR5-COMPLEX C, COMPLEX X, AND COMPLEX Y. The FIR5 function 
implements a basic FIR filter with k complex coefficients, complex input samples, and 
complex output. The input data is in a circular buffer with size M+1 and the output data is in 
a circular buffer with size N+1. The FIR5 only uses other input data samples to implement 
a fractionally spaced equalizer. 


X(N) — Y(N) 
{COMPLEX} {COMPLEX} 
k—1 
Y(n) = >) C(p)X(n—p) 
p=0 





Figure 16-18. FIR5 Implementation Example 


16.3.4.4.1 Coefficients and Sample Data Buffers. The coefficients vector occupies k 
pairs of 16-bit half-words (real and imaginary components) in memory and C(O) is stored in 
the first location. The sample input buffer is a cyclic buffer containing M+1 bytes. Each input 
sample is two 16-bit half-words (real and imaginary components) and the new sample is 
stored in the address that follows the previous sample. The output buffer is a cyclic buffer 
that contains N+1 bytes and the new output is stored in the address that follows the previous 
output. | 
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REAL OUTPUT COMPLEX OUTPUT 
(X=0) 
imag(C(0)} a 
imag{C(1)} imag {x(n-k+1)} 





real{C(1)} real {x(n-k+1)} 






imag {x(n-2)} 


real{x(n-2)} 


imag{x(n-1)} 


imag{C(k-1)} 
real{C(k-1)} 


imag{Y(n-2)} 
real{Y(n-2)} 

)} 
real{Y(n-1)} 


2K bytes M+ 1 bytes N + 1 bytes N +1 bytes 
Figure 16-19. FIR5 Coefficients and Sample Data Buffers 









_ real{x(n-1)} imag{Y(n-1 


imag{x(n)} 
real{x(n)} 










16.3.4.4.2 FIR5 Function Descriptor. The FIR5 function descriptor bit table is described 
below. 











A TS 
neta nel 


K 
XYPTR | 












RESERVED 


The first half-word is composed of the following bits: 


S—STOP 


0 = Do not stop after executing this function descriptor. 
1 = Stop after executing this function descriptor. | 
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Bits 1, 9, and 10—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Function Descriptor in Table) 


0 = This is not the last function descriptor in the function descriptor table. : 

1 = This is the last function descriptor in the function descriptor table. After this buffer 
has been used, the CPM processes the first function descriptor that the FDBASE 
index pointer points to in the table. The number of function descriptors in this table 
are programmable and determined only by the W bit and overall space constraints 
of the memory. 


I—Interrupt — 
O = No interrupt is generated after this function is processed. 
1 = A maskable interrupt is generated after this function is processed. 


Z— Complex Output 


0 = Only the real component of the result is written to the output buffer. 
1 = The real and the imaginary parts of the result is written to the output buffer. 


!ALL— Auto-Increment X For All iterations 


0 = The X (input) data pointer is incremented (Modulo M+1) by the number of samples 
specified in the INDEX field after the last iteration. 

1 = The X data pointer is incremented (Modulo M+1) by the number of samples 
specified in the INDEX field after each iteration. 


INDEX— Auto-Increment Index 


00 = The X (input) pointer is not incremented. 

01 = The X (input) pointer is incremented by one sample. 
10 = The X (input) pointer is incremented by two samples. 
11 = The X (input) pointer is incremented by three samples. 


PC— Preset Coefficients Pointer 


O= The coefficients pointer is not preset after each iteration. 
1 = The coefficients pointer is preset after each iteration to the CBASE pointer. 


OPCODE—Function Operation Code 
This field specifies the function to be executed. See Table 16-6 to get the value for this field. 
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16.3.4.4.3 FIR5 Parameter Packet. The FIR5 parameter packet is composed of seven 
16-bit half-words and described in the table below. | 


Table 16-11. FIR5 Parameter Packet 


Half-word 5 XYPTR Pointer to a structure composed of the input sample data pointer and the output 
buffer pointer 


Half-word 6 Output Buffer Size-1. The minimum output buffer size for x=1 is 8 (2 outputs). The 
minimum output buffer size for x=0 is 4 (2 outputs). 


16.3.4.4.4 Application Example. The FIR5 function is used in the fractionally spaced 
equalizer. The following example demonstrates how the function descriptor structure can be 
used to implement a fractionally spaced equalizer. | 
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16.3.4.5 FIR6é-COMPLEX C, REAL X, AND COMPLEX Y. The FIR6 function implements 
a basic FIR filter with k complex coefficients, real input samples, and complex output. The 
Inout data is in a circular buffer with size M+1 and the output data is in a circular buffer with 
size N+1. 






C(0) 
{COMPLEX} 
X(N) -Y(N) 
{REAL} {COMPLEX} 
k—1 
Yn) = >) C(p)X(n—p) 
p=0 | 


Figure 16-20. FIR6 Implementation Example 


16.3.4.5.1 Coefficients and Sample Data Buffers. The coefficients vector occupies k 
pairs of 16-bit half-words (real and imaginary components) in memory and C(O) is stored in 
the first location. The sample input buffer is a cyclic buffer containing M+1 bytes and each 
sample is a 16-bit half-word. The new sample is stored in the address that follows the 
previous sample. The output buffer is a cyclic buffer that contains N+1 bytes and the new 
output is stored in the address that follows the previous output. 
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OUTPUT 


COEFFICIENTS 
imag{C(0 


INPUT SAMPLES 






(0)} 
)} 
)} 


imag{Y(n-k+1)} 
real{Y (n-k+1)} 






imag{C(k-1 
real{C(k-1 





imag{Y(n-2)} 
real{Y(n-2)} 
imag{Y(n-1)} 
real{Y(n-1)} 
imag{Y(n)} 
real{Y(n)} 
2K bytes M+ 1 bytes N + 1 bytes 
Figure 16-21. FIR6 Coefficients and Sample Data Buffers 








16.3.4.5.2 FIR6 Function Descriptor. The FIR6 function descriptor bit table is described 
below. 





| RESERVED 


The first half-word is composed of the following bits: 


S—STOP 


0= Do not stop after executing this function descriptor. 
1 = Stop after executing this function descriptor. 
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Bits 1, 4, 9, and 10—Reserved 


‘These bits are reserved and should be set to 0. 


W—wWrap (Final Function Descriptor in Table) 

0 = This is not the last function descriptor in the function descriptor table. 

1 = This is the last function descriptor in the function descriptor table. After this buffer 
has been used, the CPM processes the first function descriptor that the FDBASE 
index pointer points to in the table. The number of function descriptors in this table 
are programmable and determined only by the W bit and overall space constraints 
of the memory. 


I—Interrupt 


O = No interrupt is generated after this function is processed. 
1 = A maskable interrupt is generated after this function is processed. 


|ALL— Auto Increment X For All Iterations 


O= The X (input) data pointer is incremented (Modulo M+1) by the number of samples 
specified in the INDEX field after the last iteration. 

1 = The X data pointer is incremented (Modulo M+1) by the number of samples 
specified in the INDEX field after each iteration. 


INDEX— Auto Increment Index 


00 = The X (input) pointer is not incremented. 

01 = The X (input) pointer is incremented by one sample. 
10 = The X (input) pointer is incremented by two samples. 
11 = The X (input) pointer is incremented by three samples. 


PC— Preset Coefficients Pointer 


O= The coefficients pointer is not preset after each iteration. 
1 = The coefficients pointer is preset after each iteration to the CBASE pointer. 


OPCODE—Function Operation Code 
This field specifies the function to be executed. See Table 16-6 to get the value for this field. 
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16.3.4.5.3 FIR6 Parameter Packet. The FIR6 parameter packet is composed of seven 
16-bit half-words and described in the table below. 


Table 16-12. FIR6 Parameter Packet 


Half-word 5 XYPTR Pointer to a structure composed of the input sample data pointer and the output 
buffer pointer 
Half-word 6 Output Buffer Size-1. The minimum output buffer size is 8 (2 outputs). 


16.3.4.6 IIR-REAL C, REAL X, REAL Y. The IIR function implements a basic BIQUAD IIR 
filter with six real coefficients, real input samples, and real outputs. The input data is in a 
circular buffer with size M+1 and the output data is in a circular buffer with size N+1. Several 
stages of the BIQUAD filter can be cascaded by specifying an iteration count greater than 
one and concatenating the filter coefficients into one vector. 



















Y(N) 
{REAL} 


X(N) 
{REAL} 





Figure 16-22. IIR Implementation Example 


16.3.4.6.1 Coefficients and Sample Data Buffers. The coefficients vector occupies six 
16-bit half-words in memory and C(0) is stored in the first location. C(1) is only used in the 
last stage of a cascaded IIR filter. The sample input buffer is a cyclic buffer that contains 
M+1 bytes. Each sample is a 16-bit half-word and the new sample is stored in the address 
that follows the previous sample. The output buffer is a cyclic buffer that contains N+1 bytes 
and the new output is stored in the address that follows the previous one. 
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INPUT SAMPLES 


OUTPUT 


COEFFICIENTS 








C(5) 





2K bytes M+ 1 bytes N+ 1 bytes 
Figure 16-23. IIR Coefficients and Sample Data Buffers 


16.3.4.6.2 IIR Function Descriptor. The IIR function descriptor bit table is described 
below. : 


| RESERVED 


The first half-word is composed of the following bits: 


S—STOP 


0 = Do not stop after executiing this function descriptor. 
1 = Stop after executing this function descriptor. 


Bits 1, 4-5, and 8-10—Reserved 
These bits are reserved and should be set to 0. 
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W—Wrap (Final Function Descriptor in Table) 


O= This is not the last function descriptor in the function descriptor table. 

1 = This is the last function descriptor in the function descriptor table. After this buffer 
has been used, the CPM processes the first function descriptor that the FDBASE 
index pointer points to in the table. The number of function descriptors in this table 
are programmable and determined only by the W bit and overall space constraints 
of the memory. 


I—Interrupt 


O= No interrupt is generated after this function is processed. 
1 = A maskable interrupt is generated after this function is processed. 


INDEX— Auto-Increment Index 


00 = The X (input) pointer is not incremented. 

01 = The X (input) pointer is incremented by one sample. 
10 = The X (input) pointer is incremented by two samples. 
11 = The X (input) pointer is incremented by three samples. 


OPCODE—Function Operation Code 
This field specifies the function to be executed. See Table 16-6 to get the value for this field. 


16.3.4.6.3 IIR Parameter Packet. The IIR parameter packet is composed of seven 16-bit 
half-words and described in the table below. 


Table 16-13. IIR Parameter Packet 


Trooness [wwe [~~ —Cesonvon 
waves [1 [Naber afters ascaeaseaee) 


Half-word 4 Samples Buffer Size-1. The minimum sample buffer size is 4 (2 samples). 


Half-word 5 XYPTR Pointer to a structure composed of the input sample data pointer and the output 


buffer pointer 






Half-word 6 Output Buffer Size-1. The minimum output buffer size is 4 (2 outputs). 


Half-word 7 Reserved 





16.3.4.6.4 Application Example. Among other things, the IIR is used in timing recovery 
and interpolating filter. 


I=1 (ONE ITERATION) 
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16.3.4.7 MOD-REAL SIN, REAL COS, COMPLEX X, AND REAL/COMPLEX Y. The 
MOD function implements a basic modulator function with a modulation table composed of 
{cos wnT, sin anT} pairs, complex input samples, and real outputs. The input data is ina 
circular buffer with size M+1 and the output data is in a circular buffer with size N+1. 


X(n) re Y(n) | 
{COMPLEX} {REAL OR COMPLEX} 


cos ont, sin onT 
{REAL} 
REAL{Y(n)} = REAL{X(n)} x cosa@nT — IMAGE{X(n)} x sina@nT 
IMAGE{Y(n)} = REAL{X(n)} x sinonT + IMAGE{X(n)} x cos@nT 


Figure 16-24. MOD Implementation Example 


16.3.4.7.1 Modulation Table and Sample Data Buffers. The modulation table is 
composed of 16-bit cosine and sine pairs that occupy K+1 bytes in memory. The sample 
input buffer is a cyclic buffer containing M+1 bytes. Each sample is a pair of 16-bit half-words 
(real and imaginary components) and the new sample is stored in the address that follows 
the previous sample. The output buffer is a cyclic buffer that contain N+1 bytes and the new 
output Is stored in the address that follows the previous output. The output buffer can be real 
or complex, depending on the K bit in the function descriptor. 


INPUT SAMPLES OUTPUT (REAL) 
real{Y (n-K+1)} 






OUTPUT —— 


MODULATION TABLE 






















imag{Y(n- -k+1)} 






real {x(n-k+1 a 
imag {x(n-2)} 
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imag{x(n-1)} 







imag{x(n)} 
real{x(n)} 





K + 1 bytes M+ 1 bytes 





real{x(n-1)} 


real{Y(n-2)} 
real{Y(n)} 


N+ 1 bytes 





| imag{Y(n-1)} 


imag{Y(n-2)} 
real{Y(n-2)} 











real{Y(n-1)} 
imag{Y(n)} 
real{Y(n)} 


N + 1 bytes 


Figure 16-25. MOD Table and Sample Data Buffers 
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16.3.4.7.2 MOD Function Descriptor. The MOD function descriptor bit table is described 
below. 


Bois Sb SS Le = me BINARY SADA SOR AN ANNON ONAN RAGE ROIDONY BADGNERN DREAMED Baba btn en ity 


OPCODE 





| RESERVED 


The first word is composed of the following bits: 


S—STOP 


O= Do not stop after executing this function descriptor. 
1 = Stop after executing this function descriptor. 


Bits 1 and 5—10—Reserved , 
These bits are reserved and should be set to O. 


W—Wrap (Final Function Descriptor in Table) 


0 = This is not the last function descriptor in the function descriptor table. 

1 = This is the last function descriptor in the function descriptor table. After this buffer 
has been used, the CPM processes the first function descriptor that the FDBASE 
index pointer points to in the table. The number of function descriptors in this table 
are programmable and determined only by the W bit and overall space constraints 
of the memory. 


I—Interrupt 


O= No interrupt is generated after this function is processed. 
1 = A maskable interrupt is generated after this function is processed. 


Z— Complex Output 


O = Only the real component of the result is written to the output buffer. 
1 = The real and imaginary parts of the result is written to the output buffer. 


OPCODE—Function Operation Code 
This field specifies the function to be executed. See Table 16-6 to get the value for this table. 
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16.3.4.7.3 MOD Parameter Packet. The MOD parameter packet is composed of seven 
16-bit half-words and is described in the table below. 


Table 16-14. MOD Parameter Packet | . 


Crooness [wwe [SCrnonron 
A 


Half-word 5 XYPTR Pointer to a structure composed of the input sample data pointer and the output 
buffer pointer — 
Half-word 6 i 4 Output Buffer Size-1. The minimum output buffer size for x=1 is 8 (2 outputs). The 












minimum output buffer size for x=0 is 4 (2 samples). 
Half-word 7 


16.3.4.7.4 Application Example. The MOD is used in the modulator. The following | 
example demonstrates how the function descriptor structure can be used to implement the 
MOD functions. | 





EVER EAR AER EEE 01000 


l=3 (THREE ITERATIONS) 





16.3.4.8 DEMOD-REAL SIN; REAL COS, REAL X, AND COMPLEX Y. The DEMOD 
function implements a basic demodulator function with a modulation table composed of (cos 
onT, sin wnT) pairs, real input samples, and complex outputs. The input data is in a circular 
buffer with size M+1 and the output data is in a circular buffer with size N+1. The AGC 
parameter controls the demodulator gain. 


X(n) Y(n) | 
{REAL} {COMPLEX} _ 


cos ont, sin o@nT, AGC 
{REAL} 


REAL{Y(n)} = (1+ AGC) x X(n) x cos@nT 
IMAGE{Y(n)} = (1+ AGC) x X(n) x (-Sin@nT) 


Figure 16-26. DEMOD Implementation Example 
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16.3.4.8.1 Modulation Table, Sample Data Buffers, and AGC Constant. The 
modulation table is composed of 16-bit cosine and sine pairs that occupy K +1 bytes in 
memory. The samples input buffer is a cyclic buffer containing M+1 bytes. Each sample is 
a 16-bit half-word and the new sample is stored in the address that follows the previous 
sample. The output buffer is a cyclic buffer that contains N+1 bytes and the new output is 
stored in the address that follows the previous output. The AGC constant is in the range 
-1< AGC<1. 


MODULATION TABLE 












a 






imag{Y(n-2)} 





real{Y(n-2)} 

imag{Y(n-1)} 
real{Y(n-1)} 
imag{Y(n)} 
real{Y(n)} 





K + 1 bytes | M+ 1 bytes N +1 bytes 
Figure 16-27. DEMOD Modulation Table and Sample Data Buffers 


16.3.4.8.2 DEMOD Function Descriptor. The DEMOD function descriptor bit table is 
described below. 





RESERVED 
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The first half-word is composed of the following bits: 


S—STOP 


0= Do not stop after executing this function descriptor. 
1 = Stop after executing this function descriptor. 


Bits 1, 4-10—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Function Descriptor in Table) 


0 = This is not the last function descriptor in the function descriptor table. 

1 = This is the last function descriptor in the function descriptor table. After this buffer 
has been used, the CPM processes the first function descriptor that the FDBASE 
index pointer points to in the table. The number of function descriptors in this table 
are programmable and determined only by the W bit and overall space constraints 
of the memory. 


I—Interrupt 


0 = No interrupt is generated after this function is processed. 
1 = A maskable interrupt is generated after this function is processed. 


OPCODE—Function Operation Code 
This field specifies the function to be executed. See Table 16-6 to get the value for this field. 


16.3.4.8.3 DEMOD Parameter Packet. The DEMOD parameter packet is composed of 
seven 16-bit half-words and is described in the table below. 


Table 16-15. DEMOD Parameter Packet 










Half-word 5 XYPTR Pointer to a structure composed of the input sample data pointer and the output 
buffer pointer 
Half-word 6 Output Buffer Size-1. The minimum output buffer size is 8 (2 outputs). — 
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16.3.4.8.4 Application Example. The DEMOD is used in the modulator. The following 
example demonstrates how the function descriptor structure can be used to implement the 
MOD function. 


rsfofwlifofofojofofojo] om 


16.3.4.9 LMS1-COMPLEX COEFFICIENTS, COMPLEX SAMPLES, AND 
REAL/COMPLEX SCALAR . The LMS1 function implements a basic FIR filter coefficients 
update. The coefficients and input samples are complex numbers, but the scalar is a real or 
complex number. 





Chet GigE 2 
Figure 16-28. LMS1 Implementation Example 


16.3.4.9.1 Coefficients and Sample Data Buffers. The coefficients vector occupies k 
pairs of 16-bit half-words (real and imaginary components) in memory and C(O) is stored in 
the first location. The samples input buffer is a cyclic buffer that contain M+1 bytes. Each 
sample is a pair of 16-bit half-words (real and imaginary components) and the new sample 
is stored in the address that follows the previous sample. 


[meson | [ 












real{C(1)} 


MOTOROLA 


imag{C(k-1)} 
real{C(k-1)} 





2K bytes 









-imag{X(n-2)} 
real{X(n-2)} 
imag{X(n-1)} 


imag{X(n)} 
real{X(n)} 


M+ 1 bytes 


Figure 16-29. LMS1 Coefficients and Sample Data Buffers 
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real{X(n-1)} 
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16.3.4.9.2 LMS1 Function Descriptor. The LMS1 function descriptor bit table is described 
below. 





RESERVED 


The first half-word is composed of the following bits: 


S—STOP 


0 = Do not stop after executing this function descriptor. 
= Stop after executing this function descriptor. 


W—Wrap (Final Function Descriptor in Table) 


0 = This is not the last function descriptor in the function descriptor table. 

1 = This is the last function descriptor in the function descriptor table. After this buffer 
has been used, the CPM processes the first function descriptor that the FDBASE 
index pointer points to in the table. The number of function descriptors in this table 
are programmable and determined only by the W bit and the overall space 
constraints of the memory. 


I—Interrupt 


O = No interrupt is generated after this function is processed. 
1 = A maskable interrupt is generated after this function is processed. 


Z— Complex Scalar 


O= The scalar (E) is a real number. 
1 = The scalar (E) is a complex number. 


~ INDEX— Auto-Increment Index 


00 = The X (input) pointer is not incremented. 

01 = The X (input) pointer is incremented by one sample. 
10 = The X (input) pointer is incremented by two samples. 
11 = The X (input) pointer is incremented by three samples. 


OPCODE—Function Operation Code 
This field specifies the function to be executed. See Table 16-6 to get the value for this field. 
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16.3.4.9.3 LMS1 Parameter Packet. The LMS1 parameter packet is composed of seven 
16-bit half-words and is described in the table below. 


Table 16-16. LMS1 Parameter Packet 


Taconess [wame CROTON 
Half-word 7 Reserved 


16.3.4.9.4 Application Example. The LMS1 is used in the echo cancellation update. 
















l=1 (ONE ITERATION) | 


16.3.4.10 LMS2—COMPLEX COEFFICIENTS, COMPLEX SAMPLES, AND 
REAL/COMPLEX SCALAR. The LMS2 function implements a basic FIR filter coefficients 
update and the sample pointer is incremented by two, which is required for fractionally 
spaced equalizer updates. The coefficients and input samples are complex numbers, but 
the scalar is a real or complex number. : 


ent ls CM+EXX, | a 


Figure 16-30. LMS2 Implementation Example 
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16.3.4.10.1 Coefficients and Sample Data Buffers. The coefficients vector occupies k 
pairs of 16-bit half-words (real and imaginary components) in memory and C(0) is stored in 
the first location. The sample input buffer is a cyclic buffer containing M+1 bytes. Each 
sample is a pair of 16-bit half-words (real and imaginary components) and the new sample 
is stored in the address that follows the previous sample. 


|) imag{X(n-k+1)} 
real{X(n-k+1)} 

- imag{X(n-2)} | 
| real{X(n-2)} 
imag{X(n-1)} 

real{X(n-1)} 


imag{X(n)} 
real{X(n)} 


. | 2K bytes M+ 1 bytes 
Figure 16-31. LMS2 Coefficients and Sample Data Buffers 


COEFFICIENTS . 
imagiC(0)} 
real{C(0)} 
imag{C(1)} 







real{C(1)} 


imag{C(k-1)} 
real{C(k-1)} 





16.3.4.10.2 LMS2 Function Descriptor. The LMS2 function descriptor bit table is 
described below. 


8 mes} w|i [z [res] woe | mes | ncome 
| K 
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The first half-word is composed of the following bits: 


S—STOP 


0 = Do not stop after executing this function descriptor. 
1 = Stop after executing this function descriptor. 


Bits 1, 5, and 8—-10—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Function Descriptor in Table) 


0 = This is not the last function descriptor in the function descriptor table. 

1 = This is the last function descriptor in the function descriptor table. After this buffer 
has been used, the CPM processes the first function descriptor that the FDBASE 
index pointer points to in the table. The number of function descriptors in this table 
are programmable and determined only by the W bit and overall space constraints 
of the memory. 


I—Interrupt 


O= No interrupt is generated after this function is processed. 
1 = A maskable interrupt is generated after this function is processed. 


Z— Complex Scalar 


O= The scalar (E) is a real number. 
1 = The scalar (E) is a complex number. 


INDEX— Auto-Increment Index 


00 = The X (input) pointer is not incremented. 

01 = The X (input) pointer is incremented by one sample. 
10 = The X (input) pointer is incremented by two samples. 
11 = The X (input) pointer is incremented by three samples. 


OPCODE—Function Operation Code 7 
This field specifies the function to be executed. See Table 16-6 to get the value for this field. 
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16.3.4.10.3 LMS2 Parameter Packet. The LMS2 parameter packet is composed of seven 
16-bit half-words and is described in the table below. 


Table 16-17. LMS2 Parameter Packet 


ADDRESS DESCRIPTION 


Half-word 2 Number of Taps-1. | 


Half-word 3 CBASE Filter Coefficients Vector Base Address Pointer | 


Half-word 4 Samples Buffer Size-1. The minimum sample buffer size is 8 (2 samples). 


Half-word 5 Pointer to New Sample Data Pointer | 


16.3.4.10.4 Application Example. The LMS2 function is used in the fractionally spaced 
equalizer coefficient update. 





rsfofwitfzfo] mx fol o 





16.3.4.11 WADD-REAL X AND REAL Y. The WADD function receives two real vectors 
and two real coefficients (co. and B) as inputs. The function generates an output vector that is 
the linear combination between the two input vectors, according to « and B. It is a special 
case when B = 1 — a and (0 < a $1) generates a linear interpolation between the two. input 
vectors. 


Y(n) = aX, (Nn) + BX,(n) 


Figure 16-32. WADD Implementation Example 
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16.3.4.11.1 Coefficients and Sample Data Buffers. Each input vector is stored in a cyclic 
buffer containing M+1 bytes. Each sample is a 16-bit half-word and the newest sample is 
stored in the address that follows the previous sample. The output buffer is a cyclic buffer 
that contains N+1 bytes. Each output is a 16-bit half-word and the newest output is stored 
in the address that follows the previous one. : 


OUTPUT 










X, INPUT SAMPLES Xo INPUT SAMPLES 





2K bytes M+ 1 bytes | N + 1 length buffer 
Figure 16-33. WADD Modulation Table and Sample Data Buffers 


16.3.4.11.2 WADD Function Descriptor. The WADD function descriptor bit table is 
described below. 


ee 


OPCODE 





RESERVED 





COMMUNICATION 
PROCESSOR MODULE 
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The first half- were is Bonbesse of the following bits: 


S—STOP 


0 = Donot stop after saxecuiin this function descriptor. 
1 = Stop after executing this function descriptor. 


Bits 1 and 4-10—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Function Descriptor in Table) 


0 = This is not the last function descriptor in the function descriptor table. 

1 = This is the last function descriptor in the function descriptor table. After this buffer 
has been used, the CPM processes the first function descriptor that the FDBASE 
index pointer points to in the table. The number of function descriptors in this table 
are programmable and determined only by the W bit and overall space constraints 
of the memory. 


I—Interrupt 


0 = No interrupt is generated after this function is processed. 
1 = A maskable interrupt is generated after this function is processed. 


OPCODE—Function Operation Code | 
This field specifies the function to be executed. See Table ioe to get the value for this field. 


16.3.4.11.3 WADD Parameter Packet. The WADD Saranneier packet is composed of 
seven 16-bit hall- words and is described in the table below. 


Table 16-18. WADD Parameter Packet — 


Half- word 1 a ae Number of Iterations 

















Half-word 3 i eo X> Weight Coefficient | | 
Half-word 4 pM Samples Buffer Size-1 | | 


Half-word 5 XYPTR Pointer to a structure composed of X; input sample data pointer, eupet buffer 


pointer, and the Xp input sample data pointer. 


Half-word 6 EPTR Output Buffer Size-1 
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16.3.4.11.4 Application Example. By specifying different values, several functions can be 
implemented as shown in the table below. 


Table 16-19. WADD Functions 


Linear Interpolation 


a [0 | vir) = ax Scalar util 
yn) = x4(0)- ale) Vector Subtract 





16.3.4.12 THE DSP EXECUTION TIMES. A function’s execution time is a linear function of 
the number of taps and iterations specified for that function. It includes overhead for 
context-switch, function descriptor handling, and initialization. Table 16-20 lists the 
execution time for each of the DSP functions. 


Table 16-20. DSP Functions Execution Times 


FUNCTION EXECUTION TIME | 


FIR1 53 +20 * (1-1) + 1.25 *1* (K+1) 











FIR2 47 +17 * (1-1) +3 *1* (K+) 
FIR5 44414 (1-1)+5*1* (K+1) 
FIR6 50 + 20 * (I- 1) +3 * I * (K+1) 


a 2 
[wos [er 


NOTES: 












iDYSE?? 








1. Add 1 clock for wrap, 5 clocks for stop, and 4 clocks for 
interrupt. 


i = number of iterations. 
3. k+1 = number of taps. 
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16.4 TIMERS 

The communication processor module includes four identical 16-bit general-purpose timers 
that can be cascaded into two 32-bit timers. Each general-purpose timer consists of a timer 
mode register, a timer capture register, a timer counter, a timer reference register, a timer 


event register, and a timer global configuration register. The timer mode register contains 
the prescaler value that you program. The timer block diagram is illustrated in Figure 16-34. 


— : , GENERAL SYSTEM CLOCK 
TGCR | GLOBAL CONFIGURATION REGISTER >F : 





EVENT REGISTER x | TIMER ae 
—_— ; CLOCK 
~~ MODE REGISTER . GENERATOR fa - TIN1 
PRESCALER MODEBITS |* : TIN2 
DIVIDER 7 CLOCK : TIN3 
| TIN4 


CAPTURE 


TIMER COUNTER . 
| | DETECTION |“ 
_ REFERENCE REGISTER >t _ oun 
> TOUTE 
CAPTURE REGISTER = 


CPM LOCAL BUS 


TIMER1 


Figure 16-34. Timer Block Diagram 


16.4.1 Features 


The following list summarizes the main features of the timers: 


e Maximum period of 10.7 seconds (at 25MHz) 

e Minimum 40ns resolution (at 25MHz) 

e Programmable sources for the clock input 

e Input capture capability 

¢ Output compare with programmable mode for the output pin 


¢ Four timers can be internally or externally cascaded to form two 32-bit timers. However, 
if you are using Mask Revision Base #F 98S, there are only two timers. 


e Free run and restart modes 
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16.4.2 Timer Operation 


The clock input to the prescaler can be selected from three sources: 


e The general.system clock 
e The general system clock divided by 16 
e The corresponding TINx pin 


The general system clock is generated in the clock synthesizer and defaults to the system 
frequency (25 or 50MHz). However, the general system clock has the option to be divided 
before it leaves the clock synthesizer. This mode, called normal low, is used to save power. 
Whatever the resulting frequency of the general system clock, you can either choose that 
frequency or the frequency divided by 16 as the input to the prescaler of each timer. On the 
other hand, you may prefer that the TINx pin be the clock source because it is intemially 
synchronized to the internal clock. , | | 


The clock input source is selected by the ICLK field of the corresponding timer mode register 
(TMRx). The prescaler is programmed to divide the clock input by values between 1 and 256 
and the output of the prescaler is used as an input to the 16-bit counter. The best resolution 
of the timer is one clock cycle (40ns at 25MHz). The maximum period is 268,435,456 cycles, 
which is 10.7 seconds at 25MHz. Both values assume that the general system clock is the 
full 25MHz. 


_ Each timer can be configured to count until a reference is reached and then either begin a 
new time count immediately or continue running. The FRR bit of the corresponding TMRx 
selects each mode. When the reference value is reached, the corresponding TER bit is set 
and an interrupt is issued if the ORI bit in the TMRx is set. Timers 1 and 2 can output a signal 
on the timer output pin (TOUT1 and TOUT2) when the reference value is reached or 
selected by the OM bit of the corresponding TMR1 and TMR2. This signal can be an active- 
low pulse or a toggle of the current output. 








In addition, each timer has a 16-bit timer capture register (TCRx) that is used to latch the 
value of the counter when a defined transition of the TIN1, TIN2, TINS, or TIN4 pin is sensed 
by the corresponding input capture edge detector. The type of transition triggering the 
capture is selected by the CE field in the corresponding TMRx. When a capture or reference 
event occurs,.the corresponding TER bit is set and a maskable interrupt request is issued 
to the CPM interrupt controller. Timers 1 and 2 can be gated or restarted using the TGATE1 
signal (timers 3 and 4 cannot be gated). Normal gate mode enables the count on the falling 
edge of the TGATE1 pin and disables the count on the rising edge of the TGATE1 pin. This 
mode allows the timer to count conditionally, depending on the state of the TGATE1 pin. 
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Restart gate mode performs the same function as normal mode, except it also resets the 
counter on the falling edge of the TGATE1 pin. This mode can n be used in pulse interval 
measurement and bus monitoring applications: 


e Pulse Measurement—The restart gate mode can measure a low pulse on the TGATE1 
pin. The rising edge of the TGATE1 pin completes the measurement and if TGATE1 is 
externally connected to TINx, it causes the timer to capture the count value and 
generate a rising-edge interrupt. 


e Bus Monitoring—The restart gate mode can detect a signal that is abnormally stuck low. 
The bus signal should be connected to the TGATE1 pin. The timer count is reset on the 
falling edge of the bus signal and if the bus signal does not go high again within the 
number of user- “defined clocks, an interrupt can be genelalee: | | 


The gate function is snabled: in the timer mode register and the gate operating mode | is 
selected in the timer global configuration register. | 


Note: TGATE1 is internally synchronized to the timebase clock (TMBCLK). If it meets 
the asynchronous input setup time, then (when working with the internal clock) 
_the counter begins counting after one system clock. © : 





16.4.2.1 CASCADED MODE. In this mode, the 16-bit timers can be internally cascaded 
into a 32-bit counter. Since the decision to cascade timers is made independently, you have 
the option of selecting four 16-bit timers or two 32-bit timers. The timer global configuration 


register is used to put the timers into cascaded mode. See Figure 16-35 for details. 


TIMER! TIMER2 - CLOCK 
TRR, TCR, TCN CONNECTED TO DATA BUS ‘ TRR, TCR, TCN CONNECTED TO DATA BUS 
PINS 31-16. . | PINS 15-0. 


_ CAPTURE | —_ 
{o TIMERS ——TIMER4 a. 
4 TRR, TCR, TCN CONNECTED TO DATA BUS 


— TRR, TCR, TON CONNECTED TO DATA BUS 
PINS 31-16. - PINS 15-0. 


CLOCK 





CAPTURE 
Figure 16-35. Timer Cascaded Mode Block Diagram 


If the CAS2 bit is set in the timer global configuration register, the two timers function as a 
32-bit timer with a 32-bit timer reference register, timer capture register, and timer counter. 
In this case, timers 1 and 3 are ignored and timers 2 and 4 should be used to define the 
mode. The capture is controlled by the TIN2 pin and the interrupts are generated by the 
TER2 pin. When operating in cascaded mode, the cascaded timer reference register, timer 
capture register, and timer counter should always be referenced with 32-bit bus cycles. 
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16.4.2.2 TIMER GLOBAL CONFIGURATION REGISTER. The 16-bit, memory-mapped, 
read/write timer global configuration register (TGCR) contains configuration parameters that 
are used by both timers. It allows simultaneous starting and stopping of any number of 
timers as long as one bus cycle is used to access TGCR. 


TGCR 


LICL CIAL 


(IMMR & OxFFFFO000) + 0x980 





CAS4—Cascade Timers 


O = Normal operation. 
1 = Timers 3 and 4 are cascaded to form a 32-bit timer. 


FRZ4—FRZ1—Freeze 


rs The corresponding timer ignores the FRZ pin. 
= Stops the corresponding timer if the FRZ pin is asserted by the core during 
breakpoint. 


STP4—STP1 —Stop Timer 


0 = Normal operation. 

1 = Reduce the timer’s power consumption. This bit eis all clocks to the timer, except 
the clock from the U-Bus interface, which allows you to read and write the timer 
registers. The clocks to the timer remain inactive until you clear this bit or a 
hardware reset occurs. 


RST4—RST1—Reset Timer 


O = Reset the corresponding timer. A software reset is identical to an external reset. 
= Enable the corresponding timer if the STPx bit is cleared. 


Bit 4—Reserved 
This bit is reserved and should be set to 0. 


CAS2—Cascade Timers 


O = Normal operation. 
1 = Timers 1 and 2 are cascaded to form a 32-bit timer. 
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Communication Processor Module 


GM1—Gate Mode for Pin 1 
This: bit | is ony, valid if the gate function | is enabled | in timer 1 or 2. 


0 Restart gate mode. A rode. A falling TGATET pin enables and restarts the count anda 
rising edge of TGATE1 disables the count. 
Normal gate mode. This mode is the same as 0, except the falling edge of the 


TGATE1 pin does not restart the count value | in the timer counter. 


al, 
II 


ey 4.2.3 TIMER MODE REGISTERS. The 16- bit, memory- mapped, read/write timer mode 


registers (TMR1—TMR4) are identical and cleared by reset. To avoid erratic behavior, the 
TGCR must be initialized before the TMRx. The only exception is that the RST bit in the 


-TGCR can be modified at any time. 


TMR1-TMR4 





(IMMR & OxFFFFO000) + 0x990 (TMR1), 0x992 (TMR2), Ox9A0 (TMR3), 0x9A2 (TMR4) 


PS—Prescaler Value 


The prescaler is programmed to divide the clock input by a value between 1 and 256. A 
00000000 value divides the clock by 1 and 11111111 divides it by 256. 


CE—Capture Edge and Enable Interrupt. 


_ = Disable interrupt on capture event; capture function is disabled. 

= Capture on rising TINx edge only and enable interrupt on capture event. 
Capture on falling TINx edge only and enable interrupt on capture event. 
Capture on any TINx edge and enable interrupt on capture event. 


= 
11 


OM—Output Mode (Only Valid for TMR1 and TMR2) 


0 = Active-low pulse on TOUT1 or TOUT2 for one timer input clock cycle as defined by 
the ICLK bits. Thus, TOUTx may be low for one general system clock period, one 
general system clock/16 period, or one TINx pin clock cycle period. Changes to 
TOUTx occur on the rising edge of the system clock. 

= Toggle the TOUTx pin. Changes to TOUTx occur on the rising edge of the system 
clock. 


ORI—Output Reference Interrupt Enable 


QO = Disable interrupt for reference that is reached. This does not affect an interrupt on 
the capture function. 
1 = Enable interrupt when the reference value is reached. 
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FRR—Free Run/Restart 


O = Free run. The timer count continues to increment after the reference value | is 
reached. 
1 = Restart. The timer count is reset immediately after the reference valle is reached. 


ICLK—Input Clock Source for the Timer 


00 = Internally cascaded input. 
For TMR1, the timer 1 input is the output of timer 2. 
For TMR3, the timer 3 input is the output of timer 4. 
For TMR2 and TMR4, this selection means no input clock is provided to the timer. 
01 = Internal general system clock. 
10 = Internal general system clock divided by 16. 
11 = Corresponding TINx pin (falling edge). 


GE—Gate Enable 


O= The TGATE?1 signal is ignored. 
1 = The TGATE1 signal is used to control the timer. 


16.4.2.4 TIMER REFERENCE REGISTERS. Each of the 16-bit, memory-mapped, 
read/write timer reference registers (TRR1-TRR4) contain the timeout's reference value. 


TRR1—TRR4 


oe 


REFERENCE 


(IMMR & OxFFFFO000) + 0x994 (TRR1), 0x996 (TRR2), 0x9A4 (TRR3), 0x9A6 (TRR4) 





REFERENCE—Reference to TCNx 
This reference value is reached when the TCNx register increments to equal TRRx. 
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16.4.2.5 TIMER CAPTURE REGISTERS. Each of the 16-bit, memory-mapped, read-only 
timer capture registers (TCR1—TCRA4) are used to latch the value of the counter at the falling 
edge of every TINx signal. The CE field in the TMRx defines whether the counter starts at 
the rising or falling edge of the TINx signal. 


TCR1-TCR4 


(IMMR & OxFFFF0000) + 0x998 (TCR1), 0x99A (TCR2), Ox9A8 (TCR3), Ox9AA (TCR4) 





CAPTURE COUNT 


This field contains the value of the timer counter register at the falling edge of the TINx 
signal. 


16.4.2.6 TIMER COUNTER REGISTERS. Each of the 16-bit, memory-mapped, read/write 
timer counter (TCN1 and TCN4) registers are up-counters. In timer capture mode, the TINx 
signal defines when the counter begins. A read to TCNx yields the current value of the timer, 
but does not affect the counting operation. A write to TCNx sets the register to that value, 
which causes the corresponding prescaler in the PS field of the TMRx to be reset. 


TCN1—TCN4 





(IMMR & OxFFFFO000) + 0x99C (TCN1), Ox99E (TCN2), Ox9AC (TONS), ( OXOAE (TCN4) 
NOTE: — = Undefined. 


COUNT—Counter Value 
This represents the value of the counter. 


= Note: The TCNx register may not be updated correctly if a write is made to it while the 
timer is not running. You should always use the TRRx to define the preferred 
counter value. 
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16.4.2.7 TIMER EVENT REGISTERS. Each of the 16-bit, memory-mapped timer event 

registers (TER1—TER4) are used to report events recognized by the timers. When an output 
reference event is recognized, the timer sets the REF bit, regardless of the corresponding 
ORI bit in the TMRx. The capture event is only set if it is enabled by the CE field in the TMRx. 
These registers can be read at any time and are cleared at reset. A bit is reset by writing a 
1 (writing a zero has no effect) and more than one bit can be reset at a time. However, both 
bits must be reset before the timer negates the interrupt to the CPM interrupt controller. 


TER1-TER4 


RESERVED vee REF | CAP | 
Es 


(IMMR & OxFFFF0000) + 0x9B0 (TER1), 0x9B2 (TER2), 0x9B4 (TER3), 0x9B6 (TER4) 





Bits O—13—Reserved 
These bits are reserved and should be set to 0. 


REF—Output Reference Event 


This bit signifies that the counter has reached the value in the TRRx. The ORI bit in the 
TMRx is used to enable the interrupt request caused by this event. 


CAP—Capture Event 


This bit signifies that the counter value has been latched into the TCRx. The CE field in the 
TMRx is used to enable generation of this event. 


16.4.3 Initializing the Timers 


The following is an example of timer 2’s initialization sequence that is required to generate ( ry 
an interrupt every 10 microseconds, assuming a 25MHz general ee clock. An interrupt Le 
should be generated after each 250 system clock. 


1. Write Ox0000 to the TGCR: This puts timer 2 into a reset state. Cascaded mode its not 
used here. 


2. Write Ox001A to the TMR2. This enables the timer’s prescaler to divide by 1 and sets 
the clock source to general system clock. It also enables an interrupt to occur when | 
the reference value is reached and restarts the timer to connnuousyy generate toms | 
interrupts. - 

3. Write 0x0000 to the TCN2 register. This initializes the timer 2 count to zero ne 
state of this register). 


4. Write OxOOFA to the TRR2. This initializes the timer 2 reference value to 250 (decimal) 
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_5. Write OxFFFF to the TER2. This clears the TER2 of any bits that might have been set. 


“6. Write 0x00040000 to the CIMR. This enables a timer 2 interrupt in the CPM ate trap 
controller and initializes the CICR. 


| 7. Write 0x0010 to the TGCR. This enables timer 2 to begin counting. 


To implement the same function with a 32-bit timer using timers 1 and 2, follow these steps: 


1. Write 0x0080 to the TGCR. This cascades timers 1 and 2 and puts them in a reset 
state. 


2. Write 0x001 A to the TMR2. This enables the timer 2 prescaler to divide by 1 and the 


clock source to the general system clock. It also enables an interrupt when the 
reference value is reached and restarts the timer to continuously generale 10ms 
interrupts. 

3. Write 0x0000 to the TMR1. This enables timer 1 to use the output of timer 2 as its input 

~ (default of TMR1). 

4. Write 0x0000 to the TCN1 and 0x0000 to the TCN2. This initializes the count of the 
combined timers 1 and 2 to zero (default of TMR1) by using one 32-bit data move to 
TCN1. 

5. Write 0x0000 to the TRR1 and Ox00FA to the TRR2. This initializes the reference 
value of the combined timers 1 and 2 to 250 by using one 32-bit data move to TRR1. 


6. Write OxFFFF to the TER2. This clears the TER2 of any bits that might have been set. 


7. Write 0x00040000 to the CIMR. This enables the timer 2 interrupt in the CPM interrupt 
controller and initializes the CICR. 


8. Write 0x0091 to the TGCR. This padbiee timers 1 and 2 to begin counting, but leaves 
them in cascaded mode. 


16.5 THE SOMA CHANNELS 


The MPC823 has two physical serial DMA (SDMA) channels. One is controlled By the RISC 
microcontroller and the other by the LCD controller. The RISC microcontroller implements 
12 virtual SDMA channels and each one is associated with a serial channel transmitter or 


“receiver. Four channels are associated with the full-duplex serial communication controller 


and the other eight are used for the serial peripheral interface, I°C controller, and serial 
management controllers. Each channel is permanently assigned to service either the 
receive or transmit operation of a serial communication controller, serial management 
controller, serial peripheral interface, or I@C controller. Data from these controllers can be 
routed to the external RAM (path 1) or the internal dual-port RAM (path 2) with the U-Bus. 
Figure 16- 36 illustrates the paths of the data flow. | 


On a path 1 access, the U-Bus and external eysisinit bus must be acquired by the SDMA 
channel. On a path 2 access, only the U-Bus needs to be acquired and the access is not 
seen on the external system bus, unless the MPC823 is configured into the “show cycles” 
mode of the system interface unit. Thus, transfers on the U-Bus occur at the same time that 
other operations on the external system bus occur. 
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Each SDMA channel can be programmed to output one of eight function codes that identify 
the channel currently accessing memory. The SDMA channel can be assigned a big-endian 
(Motorola) or little-endian format for accessing buffer data. These features are programmed 
in the receive and transmit function code registers that are associated with the serial 
communication controller, serial management controllers, serial peripheral interface, and 
I2C controller. If a bus error occurs when the SDMA conducts a RISC-related access, the 
communication processor module generates a unique interrupt in the RISC status register. 


The interrupt service routine reads the SDMA address register to determine the address that 
the bus error occurred on. The channel that caused the bus error can be found by reading 
the RX and TX internal data pointers from the specific protocol parameters area in the 
parameter RAM of the serial channels. If an SDMA bus error occurs on a RISC-related 
cycle, all CPM activity ceases and the entire communication processor module must be 
reset in the CPM command register (CPCR). 











EXTERNAL 
RAM 


| INTERNAL UFBUS: E SYSTEM 


INTERFACE 
UNIT 


EXTERNAL 
ROM 








RISC 





DUAL-PORT 
MICROCONTROLLER RAM 
co co OQ O 
Oo. O 
Sy) Sila lal} oii 


Figure 16-36. SDMA Data Paths 
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16.5.1 SDMA Bus Arbitration and Transfers 


The instruction cache, data cache, system interface unit, and SDMA can become internal 
bus masters whose relative priority can be determined by examining their arbitration IDs. 
However, you can only adjust SDMA arbitration. All other arbitration IDs are fixed. All 12 
SDMA channels share the same ID that you are responsible for programming. Any SDMA 
channel can arbitrate for the bus against the other internal or external masters that are 
present. Once an SDMA channel obtains the system bus, it remains the bus master for one 
transaction (a byte, half-word, word, or burst) before relinquishing the bus. This feature, in 
combination with the zero clock arbitration overhead provided by the U-Bus, makes a 
simultaneous benefit out of bus efficiency and low bus latency. 


With character-oriented protocols, the SDMA writes characters to memory without waiting 
for multiple characters to be received first and it always reads words. This is consistent with 
the need to provide low-latency operation on character-oriented protocols that are used at 
slower rates. The read or write operation may take multiple bus cycles if the memory 
provides a less than 32-bit port size. For instance, a 32-bit word read from a 16-bit memory 
takes two SDMA bus cycles. The entire operand (4-word burst, 32 bits on reads, and 8, 16, 
or 32 bits on writes) will be transferred in back-to-back bus cycles before the SDMA 
relinquishes the bus. The SDMA can steal cycles with no arbitration overhead when the 
MPC823 is bus master. 


CLK 








Figure 16-37. SDMA Bus Arbitration 
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16.5.2 The SDMA Registers 


The SDMA channels share a configuration register, address register, and status register. 
They are all controlled by the configuration of the serial communication controller, serial 
management controllers, serial peripheral interface, and |?C controller. 


16.5.2.1 SDMA CONFIGURATION REGISTER. The 32-bit SDMA configuration register 
(SDCR) is used to configure all 16 SDMA channels. It is always read/write in supervisor 
mode, even though writing to the SDCR is not recommended unless the communication 
processor module is disabled. The control provided by this register has interactions with the 
DMA controllers in the LCD and video controller modules of the MPC823. Refer to 
Section 18.3.6 DMA Control and Section 18.3.1 FIFO Control for more information 
regarding those modules. 


SDCR 










| RESERVED 
(IMMR & OxFFFFO000) + 0x030 | 
RESERVED RESERVED LAID RAID 
(IMMR & OxFFFF0000) + 0x030 


Bits O-1 6—HReserved 
These bits are reserved and should be set to 0. 
















FRZ—Freeze 


These bits determine the action to be taken when the FRZ signal is asserted. The SDMA | 
negates the BR signal and keeps it that way until FRZ is negated or a reset occurs. 


00 = The SDMA channels ignore the FRZ signal. 

O1 = Reserved. 

10 = The SDMA channels freeze on the next bus cycle. 
11 = Reserved. 


LAM—LCD/Video Aggressive Mode 


OQ = Disable LCD aggressive mode. Priority depends on the LAID field. 
1 = Enable LCD aggressive mode. The LAID and RAID fields must be equal to 00. 
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Bits 19-24 and 26—27—Reserved 
These bits are reserved and should be set to 0. 


LAID—LCD Controller Arbitration ID _ 


This field determines the LCD and video controller arbitration ID. Its value should be 
programmed to 00 for typical applications. 


00 = The LCD controller uses U-Bus arbitration priority 6 (highest). 
01 = The LCD controller uses U-Bus arbitration priority 5. 

10 = The LCD controller uses U-Bus arbitration priority 2. 

11 = The LCD controller uses U-Bus arbitration priority 1 (lowest). 


RAID—RISC Controller Arbitration ID 


These bits establish the priority level of bus arbitration among modules that can become bus 
master. The instruction cache, data cache, system interface unit, and SDMAs all compete 
for bus mastership. The SDMA channel arbitration ID is determined by the RAID field. 
Arbitration IDs for all other bus masters are internally fixed. This value should be | 
programmed to 01 for typical applications. 


00 = The SDMA uses U-Bus arbitration priority 6 (highest). 
01 = The SDMA uses U-Bus arbitration priority 5. 

10 = The SDMA uses U-Bus arbitration priority 2. 

11 = The SDMA uses U-Bus arbitration priority 1 (lowest). 


16.5.2.2 SDMA STATUS REGISTER. Shared by all 12 SDMA channels, the 8-bit 


. memory-mapped SDMA status register (SDSR) is used to report events recognized by the 


SDMA controller. When an event is recognized, the SDMA sets the corresponding bit in the 
SDSR. A bit is reset by writing a 1 (writing a zero has no effect) and more than one bit can 
be reset at a time. This register is cleared by reset and can be read at any time. 


SDSR 











a 
ee a 


SBER—SDMA Channel Bus Error (SDMA function) 


This bit indicates that an error caused the SDMA channel to terminated during a read or 
write cycle. The SDMA bus error address can be read from the SDMA address register. 


Bits 1-5—Reserved | 
These bits are reserved and should be set to 0. 
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DSP2—DSP Chain 2 Transmitter Interrupt (DSP function) 


This bit is set when the chain 2 function finishes executing. However, the | bit must be set in 
the function descriptor, as shown in Section 16.3.3.3 DSP Event Register. 


DSP1—DSP Chain 1 Receiver Interrupt (DSP function) 


This bit is set when the chain 1 function finishes executing. However, the | bit must be set in 
the function descriptor, as shown in Section 16.3.3.3 DSP Event Register. 


16.5.2.3 SDMA MASK REGISTER. The 8-bit read/write SDMA mask register (SDMR) has 
the same bit format as the SDMA status register. If a bit in the SDMA mask register is a 1, 
the corresponding interrupt in the event register is enabled. If the bit is zero, the 
corresponding interrupt is masked. 















a 
> 


(IMMR & OxFFFFO000) + 0x90C 





SBER—SDMA Channel Bus Error Mask (SDMA function) | 


O = Disable the SDMA channel bus error interrupt. 
1 = Enable the SDMA channel bus error interrupt. 


Bits 1—5—Reserved 
These bits are reserved and should be set to 0. 


DSP2—DSP Chain 2 Transmitter Interrupt Mask (DSP function) 


0 = Disable the DSP chain 2 transmitter interrupt, as shown in Section 16.3.3.3 DSP 
Event Register. | 
1 = Enable the DSP chain 2 transmitter interrupt. 


DSP1—DSP Chain 1 Receiver Interrupt Mask (DSP function) 


0 = Disable the DSP chain 1 receiver interrupt, as shown in Section 16.3.3.3 DSP. 
Event Register. | 7: 
1 = Enable the DSP chain 1 receiver interrupt. 
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- Communication Processor Module 


16.5.2.4 SDMA ADDRESS REGISTER. The 32-bit read-only SDMA address register 


(SDAR) shows the system address that is accessed during an SDMA bus error. It is 


undefined at reset. 


SDAR 





(IMMR & OxFFFFO000) + 0x906 


— = Undefined. 





NOTE 





SBEA—SDMA Bus Error Address 
This field contains the system address accessed when the SDMA encounters a bus error. 


16.6 EMULATING IDMA 


Using the IDMA-dedicated SDMA channel, which is not part of the 12 channels, the RISC 
microcontroller can be configured to provide a general-purpose DMA functionality. Two 
general-purpose independent DMA (IDMA) channels are supported. In this special 
emulation mode, you can specify any memory-to-memory or peripheral-to-memory transfers 


to be implemented i in the same way as dedicated DMA hardware. 


The general-purpose IDMA controllers operate in different data transfer modes that you are 
responsible for programming. They can transfer data between any combination of memory 
and I/O. In addition, data can be transferred in byte, half-word, word, or burst quantities and 
the source and destination addresses can be odd or even. The most efficient packing 
algorithms are used in IDMA transfers. The single address mode performs the best because 
it allows data to be transferred between memory and the peripheral within a single bus cycle. 
The chip-select and wait-state generation logic on the MPC823 can be used with IDMA. 


IDMA supports three buffer handling modes—single buffer, autobuffer, and buffer chaining. 
The single buffer mode allows a single buffer peripheral to memory data transfer with single 
address (flyby) burst transfers. The autobuffer mode allows blocks of data to be repeatedly 
moved from one location to another without you having to intervene. The buffer chaining 
mode allows a chain of blocks to be moved sequentially. You specify how to move the data 
using buffer descriptors similar to those used by a serial communication controller. These 
buffer descriptions reside in the dual-port RAM. 
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16.6.1 Features 
The following is a list of the MPC823 IDMA’s main features: © 


e Two independent, fully programmable DMA channels © 

e Dual address or single address transfers with 32-bit address and data capability 
e 32-bit byte transfer counters 

e 32-bit address pointers that can increment or remain constant 


Efficient operand packing and unpacking for dual address transfers 
e All bus-termination modes are supported 

e Provides DMA handshake for cycle steal and burst transfers 

e Buffer handling modes (auto buffer and buffer chaining) 


16.6.2 IDMA Interface Signals 


The MPC823 IDMA has two dedicated control signals per channel—DMA request and DMA 
acknowledge. IDMA accepts DMA requests from the DREQ1 and DREQ2 signals and 
acknowledges the request with the SDACK1 and SDACK2 signals. The peripheral used with 
these signals can either be a source or destination of the IDMA transfers. The DREQx 
signals are also used for memory-to-memory request generation and, in this case, should 
be connected to the timer that controls the transfer. 











16.6.2.1 DREQx AND SDACKx. These are the handshake signals between the MPC823 
and the peripheral that needs to be serviced. When the peripheral asks for IDMA service, it 
asserts DREQx and the MPC823 begins the IDMA process. While the service is in progress, 
SDACKx is asserted during accesses to the device. DREQx can be configured to be either 
edge or level sensitive by programming the DRxM field in the RCCR. The DRQFP field in the 
RCCR control IDMA channel priority in relation to the serial channels. To enable the DREQx 
signals, the corresponding DREQx bit in the PCSO register should be set. When the DREQx 
signals are configured as edge-sensitive requests, the edge on which a request is generated 
is controlled by the corresponding EDMx bit in the PCINT register. See Section 16.14.6 The 
Port B Registers for details on the Port C registers. 


16.6.3 IDMA Operation 


Every IDMA operation involves the following series of events—IDMA channel initialization, 
data transfer, and block termination. In the initialization phase, the core loads the 
IDMA-specific parameter RAM with control information, initializes the IDMA buffer 
descriptors, and starts the channel. In the transfer phase, IDMA accepts requests for 
operand transfers and provides addressing and bus control for the transfers. The 
termination phase occurs when the operation is complete and IDMA interrupts the core if 
interrupts are enabled. To initialize a block transfer operation, you must initialize the IDMA 
registers. The IDMA buffer descriptors must be initialized with information describing the 
data block, device type, and other special control options. Refer to Section 16.6.3.2 IDMA 
Parameter RAM Memory Map and Section 16.6.3.6 IDMA Commands for more details. 
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Communication Processor Module 


Follow these steps to perform an IDMA transfer: 


1. Define the source (peripheral) address to be burst aligned. 
2. Define the destination address to be burst aligned. 
3. Program the IDMA mode register (DCMR) to 0x0000. 


16.6.3.1 AUTOBUFFER AND BUFFER CHAINING. The host CPU should initialize the 
IDMA buffer descriptor ring with the appropriate buffer handling mode, source address, 
destination address, and block length. 


IDMA BD BASE 
ADDRESS (IBASE) 


D — DESTINATION DEVICE 
OR DATA BUFFER 0 


SOURCE DEVICE OR 
DATA BUFFER 0 


SOURCE DEVICE OR — 
_ DATA BUFFER 1 


DESTINATION DEVICE 


OR DATA BUFFER 1 


SOURCE DEVICE OR 
DATA BUFFER 2 


DESTINATION DEVICE 
OR DATA BUFFER 2 





8) Les] w 
e e eo Oo Oo 
no _ (an) 


SOURCE DEVICE OR DESTINATION DEVICE 





DATA BUFFER N OR DATA BUFFER N 





Figure 16-38. IDMA Buffer Descriptor Ring 


The data associated with each IDMA channel for autobuffer and buffer chaining modes is 
stored in buffers and each buffer is referenced by a buffer descriptor that uses a ring 
structure located in the dual- -port RAM. : 
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16.6.3.2 IDMA PARAMETER RAM MEMORY MAP. The MPC823 uses the IDMA 
parameters listed in the table below to configure the IDMA channel for autobuffer or buffer 
chaining mode. 


Table 16-21. IDMA Parameter RAM Memory Map 


ce a 
Tonnaace soo | nse | “harvod [ENN 60 bn een Poor 
IDMA Channel Mode Register 


NOTE: You are only responsible for initializing the items in bold. 
IDMA Base = (IMMR & OxFFFFO000) + 0x3CCO0 (IDMA1) or Ox3DC0 (IDMA2). | 
All references to registers in the parameter RAM table are actually implemented in the dual-port RAM 
area as a memory-based register. 




















— 
| ADI WyA\ 
L 










e IBASE—This index pointer defines the starting point in the dual-port RAM for the set of 
IDMA buffer descriptors. It is an offset from the beginning of the dual-port RAM. You 
must initialize this entry before enabling the IDMA channel and if you overlap the buffer 
descriptor tables of two enabled serial channels or IDMA channels, erratic behavior will 
occur. IBASE should contain a value that is divisible by 16. 
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e DCMR—This register controls the operation mode of the IDMA channel. 


DCMR 


(IMMR & OxFFFFO000) + 0x3CC2 (IDMA1) AND 0x3CD2 (IDMA2) 





Bits O—10—Reserved 
These bits are reserved and should be set to 0. 


SIZE—Peripheral Port Size 


00 = Word length. 

01 = Half-word length. 
10 = Byte length. 

11 = Reserved. 


TYPE—Source/Destination Type (Can Be Peripheral or Memory) 


00 = Read and write from memory. 

01 = Read from peripheral and write to memory. 
10 = Read from memory and write to peripheral. 
11 = Reserved. 





SC—Single Cycle 
O= Dual-cycle mode. 
_. 1= Single-cycle mode. 
The following bits are only used by the RISC microcontroller: 


¢ SAPR—This address pointer points to the next source data byte that IDMA transfers. 


_¢ DAPR—This address pointer points to the next destination byte that IDMA writes. When 
__ the buffer descriptor is first processed, the communication processor module initializes 
these pointers to the programmed values in the buffer descriptor. 


e |BPTR—This pointer points to the next buffer descriptor that the IDMA transfers data to 
when it is in idle state or points to the current buffer descriptor during transfer 
processing. After a reset or when the end of an IDMA buffer descriptor table is reached, 
the communication processor module initializes this pointer to the value programmed 
in the IBASE register. 


e WRITE_SP—This parameter should not be modified. 
S_BYTE_C—This parameter should not be modified. 
D_BYTE_C—This parameter should not be modified. 
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S_STATE—This parameter should not be modified. 
ITEMP—This parameter should not be modified. 
SR_MEM—This parameter should not be modified. 
READ_SP—This parameter should not be modified. 
D_STATE—This parameter should not be modified. 


The source address pointer points to the next source data byte that the IDMA transfers. The 
destination address pointer points to the next destination byte that the IDMA writes. When 
the buffer descriptor is first being processed, the CPM initializes these pointers to the 
programmed values. The remaining parameters are to only be used by the microcontroller. 
The memory port size is transparent to the IDMA, regardless of the actual port size. The 
system interface unit emulates 32-bit port size. 


16.6.3.3 IDMA STATUS REGISTER. The 8-bit, memory-mapped IDMA status register 
(IDSR) is used to report events recognized by the IDMA controller. When an event is 
recognized, IDMA sets its corresponding bit in this register. A bit is reset by writing a 1 
(writing a zero has no effect) and more than one bit can be reset at a time. This register is 
cleared by reset and can be read at any time. 


IDSR 


| NBN 





(IMMR & OxFFFF0000) + 0x910 (IDSR1), 0x918 (IDSR2) 


Bits O-4—Reserved 
These bits are reserved and should be set to 0. 


AD—After Service Buffer Descriptor Done 
This status bit is set after servicing a buffer descriptor that has the | bit set. 


DONE—IDMA Transfer Done 


This bit indicates when the IDMA channel terminates a transfer. It is set after Servicing § a 
buffer descriptor that has the L status bit set. 


OB—Out of Buffers 
This bit indicates that the IDMA channel has no valid buffer descriptors. 
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16.6.3.4 IDMA MASK REGISTER. The 8-bit read/write IDMA mask register (IDMR) has a 
different bit format than the IDSR. If a bit in the IDMR is a 1, the corresponding interrupt in 
the status register is enabled and if it is zero, the corresponding interrupt in the status 
register is masked. The OB and AD bits are in a different sequence from the corresponding 
bits in the IDSR. 


(IMMR & OxFFFFO000) + 0x914 (IDMR1), 0x91C (IDMR2) 





Bits 0O-4—Reserved 
These bits are reserved and should be set to 0. 


OB—Out of Buffers 
This bit indicates that the IDMA channel has no valid buffer descriptors. 


DONE—IDMA Transfer Done 


aoe This bit indicates when the IDMA channel terminates a transfer. It is set after servicing a 
buffer descriptor that has the L status bit set. 





AD—After Service Buffer Descriptor Done 
This status bit is set after servicing a buffer descriptor that has the | bit set. 
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16.6.3.5 IDMA BUFFER DESCRIPTORS. The special IDMA buffer descriptors present the 
source addresses, destination addresses, and byte counts to the RISC microcontroller. The 
RISC microcontroller reads the buffer descriptors, programs the SDMA channel, and notifies 
the core about the completion of a buffer transfer using the IDMA buffer descriptors. This 
process is similar to that of the serial channels, except that the buffer descriptor is larger 
because it contains additional information. 


fees} wt [fu frs}ou] neseeD 


DATA LENGTH 


SOURCE DATA BUFFER POINTER 
DESTINATION DATA BUFFER POINTER 


NOTE: You are only responsible for initializing the items in bold. 





You must prepare the following bits before a transfer can occur. They are set by the RISC 
microcontroller after the buffer has been transferred. 


WOW | 


, 


V—Valid 

O= The data buffers associated with this buffer descriptor are not currently ready for 
transfer. You are free to manipulate this buffer descriptor or its associated data 
buffer. When it is not in autobuffer mode, the RISC microcontroller clears this bit 
after the buffer has been transferred (or after an error condition is encountered). 

1 = You have prepared the data buffers for transfer. Notice that only one data buffer 
should be prepared if the source/destination is a peripheral device. It can only be 
the source data buffer when the destination is a device or the destination data 
buffer when the source is a device. You can not write any fields of this buffer 
descriptor once this bit is set. : 


Note: The only difference between autobutfer mode and buffer chaining mode is that 
the V bit is not cleared by the RISC microcontroller in autobuffer mode. 
Autobuffer mode is enabled by the CM bit. 
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W—Wrap (Final Buffer Descriptor in Table). 


0 = This is not the last buffer descriptor in the table. 

1 = This is the last buffer descriptor in the table. After the associated puffer has been 
used, the RISC microcontroller transfers data from the first buffer descriptor that 
IBASE register points to in the table. The number of buffer descriptors in this table 
is programmable and determined only by the W bit and overall space constraints 
of the dual-port RAM. 


I—Interrupt 


0 = No interrupt is genaiaied after this buffer is serviced. 
1 = Once this buffer is serviced by the RISC microcontroller, the AD bit in the IDSR is 
set and can cause an interrupt. 


|—Last 


0 = This is not the last buffer to be transferred in the buffer chaining mode. The | bit can 
be used to generate an interrupt when this buffer is serviced. 

1 = This is the last buffer to be transferred in the buffer chaining mode. When the 
transfer count is exhausted, an interrupt is generated, regardless of state of the 
| bit. 


CM—Continuous Mode 


O= Buffer chaining mode. The RISC microcontroller clears the V bit after this buffer 
descriptor is serviced. This mode is used to transfer large amounts of data into 
noncontiguous buffer areas. You can initialize buffer descriptors ahead of time, if 
you need to. The RISC microcontroller automatically reloads the IDMA registers 
from the next buffer descriptor values when the transfer is terminated. 

1 = Autobuffer mode (continuous mode). The RISC microcontroller does not clear the 

 V bit after this buffer descriptor is serviced. This is the only difference between the 
behavior of autobuffer mode and buffer chaining mode. The autobuffer mode is 
used to transfer multiple groups of data to/from a buffer ring and does not require 
reprogramming. The RISC microcontroller automatically reloads the IDMA 
registers from the next buffer descriptor values when the transfer is terminated. 
Either a single buffer descriptor or multiple buffer descriptors can be used in this 
mode to create an infinite loop of repetitive data moves. 


Note: The | bit can be used to generate an interrupt in this mode. 
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SFCR—Source Function Code Register 


The 8-bit source function code register contains the value that you would like to appear on 
the AT pins when the associated DMA channel accesses the source MenOly: This register 
controls the byte-ordering convention used in transfers. 


SFCR 


Preserve | mt |e] 





OFFSET +3 


Bits O-2—Reserved 
These bits are reserved and should be set to 0. 


BO—Byte Ordering 


You should set this field to select the required byte ordering of the data buffer. If this 
field is modified on-the-fly, it takes effect at the beginning of the next frame or at the 
beginning of the next buffer descriptor. 


00 = The DEC/Intel convention is used for byte ordering (swapped operation). It is also 
called little-endian byte ordering. The transmission order of bytes within a buffer 
word is reversed in comparison to the Motorola mode. This mode can only be 
used with 32-bit port size memory. 

01 = PowerPC little-endian byte ordering. As data is transmitted onto the serial line 
from the data buffer, the least-significant byte of the buffer double-word contains 
data to be transmitted earlier than the most-significant byte of the same buffer 
double-word. 

1X = Motorola byte ordering (normal operation) is also called big- -endian byte ordering. 
As data is transmitted onto the serial line from the data buffer, the most-significant 
byte of the buffer word contains data to be transmitted earlier than the 
least-significant byte of the same buffer word. 


ATl—Address Type 1-3 


This field contains the function code value used during the SDMA channel memory 
access. ATO is always driven to 1 so that this SDMA channel access is identified as a 
DMA-type access. 
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DFCR—Destination Function Code Register 


The 8-bit destination function code register contains the value that you nous like to appear 
on the AT pins when the associated DMA channel accesses the destination memory. This 
register also controls the byte-ordering convention used in transfers. 


DFCR 


OFFSET + 2 





Bits O-2—-Reserved 
These bits are reserved and should be set to O. 


BO—Byte Ordering 

You should set this field to select the data buffer’s required byte ordering. If these bits 
are modified on-the-fly, it takes effect at the beginning of the next frame or at the 
beginning of the next buffer descriptor. 


00 = The DEC/Intel convention is used for byte ordering (swapped operation). It is also 
called little-endian byte ordering. The transmission order of bytes within a buffer 
word is reversed in comparison to the Motorola mode. This mode can only be 
used with 32-bit port size memory. 

01 = PowerPC little-endian byte ordering. As data is fansnitiods onto the serial line 
from the data buffer, the least-significant byte of the buffer double-word contains 
data to be transmitted earlier than the most-significant byte of the same buffer 
double-word. 

1X = Motorola byte ordering (normal operation) is also called big- -endian byte ordering. 
As data Is transmitted onto the serial line from the data buffer, the most-significant 
byte of the buffer word contains data to be transmitted earlier than the 
least-significant byte of the same buffer word. 


AT1-AT3—Address Type 1-3 


This field contains the function code value used during SDMA channel memory access. 
ATO is driven with a 1 so that this SDMA channel access is identified as a DMA-type 
access. 


DATA LENGTH 


This field contains the number of bytes that IDMA should transfer to or from this buffer 
descriptor data buffer. It should be programmed to a value greater than zero. 
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SOURCE BUFFER POINTER 


This field contains the address of the associated source data buffer and can iesidel in 
internal or external meen : 


| yf Note: In single address mode when the source is a device, the SOURCE BUFFER 
| POINTER field Is ignored. In dual address mode when the source is a device, 
this field should contain the device address. 


DESTINATION BUFFER POINTER 


This field contains the address of the associated destination data buffer, which resides in 
internal or external mee 


3 7 Note: In single address mode when the destination is a device, the DESTINATION 
| BUFFER POINTER field is ignored. In dual address mode when the destination 
is a device, this field should contain the device address. 


The terminal count code AT = OxF replaces the normal SFCR and DFCR code for the last 
IDMA cycle on the peripheral side. 


16.6.3.6 IDMA COMMANDS. There are three IDMA commands: 


e INIT_IDMA—This command causes the RISC microcontroller to reinstall its IDMA 
internal state to the condition it was in after a system reset. The IDMA buffer descriptor 
pointer is reinitialized to the top of the buffer descriptor ring. 


e ARM_IDMA—This command causes the IDMA to open the next buffer descriptor in the 
table. It can be used to reduce the latency of servicing the first IDMA request. 


e STOP_IDMA—This command causes the RISC microcontroller to terminate current 
IDMA transfers. The DONE bit is set in the IDSR and the current buffer descriptor is 
closed. If the peripheral device is the source, the IDMA internal buffer is transferred to 
memory before termination. At the next request, the following buffer descriptor in the 
chain is processed. — 
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16.6.3.7 STARTING IDMA. Once the channel has been initialized with all parameters 
required for a transfer operation, IDMA is started by setting the DREQx bit in the port C 
special option (PCSO) register. Once DREQx has been set, the channel is active and 
accepts operand transfer requests through the channel’s corresponding DREQx pin. When 
the first valid external request is recognized, IDMA arbitrates for the bus and the DREQx pin 
input is ignored until the DREQx bit is set in the PCSO register. IDMA1 is higher than IDMA2. 








The software can suspend channel transfer operation at any time by clearing the DREQx bit 
in the PCSO register. In response, any operand transfer in progress will be completed and 
the bus will be released. No further bus cycles are started while the DREQx bit remains 
cleared. During this time, the core can access IDMA internal registers to determine the 
status of a channel or to alter operation. When the DREQx bit is set again, if a transfer 
request is pending, IDMA arbitrates for the bus and continues normal operation. Interrupts 
from IDMA are sent to the interrupt controller. In the interrupt handler, the unmasked bits in 
the IDSR should be cleared (by writing them with a 1) to negate the interrupt request to the 
CPM interrupt controller. | 


16.6.3.8 REQUESTING IDMA TRANSFERS. Once IDMA has been started, transfers to 
IDMA can be requested. These transfers are initiated by externally generated requests from 
an external device using the DREQx pin in coniuncien with the activation of the DREQx bit 





of the PCSO register. 


16.6.3.9 LEVEL-SENSITIVE MODE. For external devices that require very high data 
transfer rates, level-sensitive mode allows IDMA to use a maximum bandwidth to service 
the device. In this mode, the DREQx pin input to IDMA is level-sensitive and sampled at 
rising edges of the clock to determine when a valid request is asserted by the device. The 
device requests service by asserting the DREQx pin and leaving it asserted as long as it 
needs service. 








- Each time IDMA issues a bus cycle to either read or write the device, it outputs the SDACKx 


signal. The device is either the source or destination of the transfers, as determined by the 
TYPE field of the DCMR. SDACK«x is the acknowledgment of the original burst request given 
on the DREQx pin. DREQx should be negated during the SDACKx active period to 
guarantee that no further cycles are performed. Burst mode in the context of the DREQx pin 
actually means back-to-back DMA cycles. Burst in the context of the bus n means burst cycle. 
The DMA always uses bursts at the memory width. 





16.6.3.10 EDGE-SENSITIVE MODE. For external devices that generate a pulsed signal for 
each operand to be transferred, edge-sensitive mode should be used. In edge-sensitive 
mode, IDMA moves one operand for each falling edge of the DREQx pin input. DREQx is 
sampled at each rising edge of the clock to determine when a valid request is asserted by 
the device. When IDMA detects a falling edge on the DREQx pin, a request becomes 
pending and remains as such until it is serviced by IDMA. Further falling edges on the 
DREQx pin are ignored until the request starts being serviced, which results in one operand 
being transferred. Each time IDMA issues a bus cycle to read or write the device, it outputs 
the SDACKx signal. The device is either the source or destination of the transfers, as 
determined by the TYPE field of the DCMR. Thus, SDACKx is the acknowledgment of the 
Original cycle steal request given on the DREQx pin. 
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16.6.3.11 IDMA OPERAND TRANSFERS. Once IDMA successfully arbitrates for the bus, 
it can begin making operand transfers. The source IDMA bus cycle has timing identical to 
an internal master read bus cycle. The destination IDMA bus cycle’s timing is controlled by 
the memory controller and is therefore identical to any other internal access. The 
two-channel IDMA controller supports dual-address transfers and single address transfers, 
but only channel 1 supports single-buffer (Single-address burst fly-by) transfers. The: 
dual-address operand transfer consists of a source operand read and a destination operand 
write. Each single-address operand transfer consists of one external bus cycle that allows a 
read or write cycle to occur. A single-buffer mode transfer is exactly like the single-address 
operand transfer, except it is an external burst transfer. 


16.6.3.11.1 Transfer Identification. The following are ‘ways to externally determine if 
IDMA is executing a bus cycle: 


e Monitor the AT signals or SDMA arenes to determine if they have the apue function 
code that identifies an IDMA transfer. 


_ © Monitor the SDACKx signal, which shows accesses to the peripheral device. SDACKx 
activates on either the source or destination bus cycles, depending on the TYPE field 
of the DCMR. 


16.6.3.11.2 Dual-Address Mode. The two IDMA channels can be programmed to operate 
in a dual-address transfer mode in which the operand. is read from the source address 
specified by the pointer and placed in internal storage. The operand read can take several 
bus cycles to complete because of differences in source and destination operand sizes. 
Once it is read, the operand is then written to the address specified in the destination 
address pointer. This transfer may also be several bus cycles long. You can use a variety 
of peripheral, memory, and operand size combinations in a dual- address mode transfer. 
There are two types of dual-address mode cycles: 


e Dual-address source read—lnitially, the IDMA controller copies the source data buffer 
pointer buffer descriptor into the SAPR field of the parameter RAM. During this type of 
IDMA cycle, the SDBP is used to drive the address bus, the SFCR is used to drive the 
source address type, and the DCMR is used to drive the size control. Data is read from 
the memory or peripheral and placed in the internal storage when the bus cycle is 
terminated. When the complete operand has been read, the SAPR is incremented by 
1, 2, 4, or 16, depending on the address and size information specified by the IDMA 
channel mode register (DCMR). 


¢ Dual-address destination write—Initially, the IDMA controller copies the destination 
data buffer pointer buffer descriptor into the DAPR field of the parameter RAM. During 
this type of IDMA cycle, the data in the internal storage is written to the device or 
memory selected by the AT field in the DAPR, the AT field in the DFCR, and the SIZE 
field in the DCMR. The same options exist for operand size and alignment in this cycle 
as they did in the dual address source read cycle. When the complete operand is 
written, the DAPR is incremented by 1, 2, 4, or 16 according to the DCOMR and the 
D_BYTE_C is decremented by the number of bytes transferred. If it is equal to zero and 
the transfer is completed with no errors, the DONE bit in the IDSR is set. Refer to 
Section 16.6.3.2 IDMA Parameter RAM Memory Map for more information. 
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Regardless of the source size, destination size, source starting address, or destination 
starting address, IDMA uses the most efficient packing algorithm possible to perform the 
transfer in the lowest number of bus eyes: 


16.6.3.11.3 Single-Address Mode (Fly-By Transfers). Each IDMA channel can be | 
independently programmed to provide single-address transfers. The internal storage is not 
used by IDMA, since the transfer occurs directly from a device to memory. This mode is 
often referred to as fly-by mode because the internal storage is not used. The external 
request is used to start a transfer when the single-address mode is selected. The TYPE field 
in the DCMR controls whether a source read or destination write cycle occurs on the data 
bus. Ifthe TYPE field = 01, the external handshake signals are used with the source operand 
and a single-address source write occurs. If the TYPE field = 10, the external handshake 
signals are used with the destination operand and a single-address destination read occurs. 
neers are two types of single- -address mode cycles: 


° Single- -address s source read—During this type of IDMA cycle, the device or memory 
_ selected by the address in the SAPR, the AT field in the SFCR, and the SIZE field in 
the DCMR provides the data and control signals on the data bus. This bus cycle 
operates like a normal read bus cycle. The destination device is controlled by the 
DREQx and SDACKx signals. Asserting SDACKx gives you write control to the 
destination device. For more details about IDMA handshake signals, refer to. 
Section 16.6.2 IDMA Interface Signals. For specific timing parameters, visit our 


website. 





CLKOUT 


ADDRESS 











_ Figure 16-39. Single-Address, Peripheral Write, Asynchronous TA 
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e Single address destination write—During this type of IDMA cycle, the source device is 
controlled by the IDMA handshake signals (DREQx and SDACKx). When the source 
device requests service from the IDMA channel, IDMA asserts SDACKx to allow the 
source device to drive data onto the data bus. The data is written to the device or 
memory selected by the AT field in the DAPR, the destination AT field in the DFCR, and 
the SIZE field in the DCMR. The data bus is driven to three-state for this write cycle. For 
more details about IDMA handshake signals, refer to Section 16.6.2 IDMA Interface 
Signals. For specific timing parameters, visit our website. 
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CLKOUT 


ADDRESS 








16.6.3.11.4 Single-Buffer Burst Fly-By Mode. This mode is used to transfer a data block 
from a peripheral to system memory. When the buffer has been completely transferred, 


_ channel operation is terminated. Both progressive (non-interlaced) and interlaced 
destination address generation modes are supported. This mode of operation is a subset of 


the buffer chaining mode with reduced latency and it is restricted to fly-by transfers. It is 
supported only on IDMA channel 1. — 


Progressive address generation mode is selected by setting the EIE bit in the RCCR. As a 
result, the organization of its parameter RAM is different from the other modes. 


Interlaced address generation mode supports charge-coupled devices (CCDs), which use 
an interlaced readout scheme. CCDs are often used in digital cameras. The frame buffer in 
memory must be progressive to decrease the amount of processing the software has to 

perform. The interlace mode allows you to read an interlaced CCD into a progressive buffer. 
For example, for a 2-field CCD, the IDMA reads a line, skips a line, reads a line until the first 
field (the odd lines) is read. Then the process repeats for the second field (even lines). There 
are, however, 4-field CCDs, in which case you would read a line and then skip three. A field 
is a group of scan lines (odd or even) and a frame is composed of several fields. The refresh 
(of the display) or readout (of the CCD) is done by field sequence—field1, then field2, etc. 
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Interlaced mode can be set up by: 


Initializing the IDMA single buffer mode parameter RAM. 


2. Inthe RCCR, set the EIE bit to 1. Set the DR1M bit according to the requested mode. 
See Section 16.2.6 RISC Controller Configuration Register for more information. 


3. If edge-sensitive mode is selected, program the EDM15 bit to the requested mode 
(falling edge/any edge). 


4. Inthe PCSO register set the DREQ1 bit to 1. See Section 16.14.9.4 Port C Special 
Options Register for more information. 


When configured to the single buffer mode, the IDMA parameter RAM is overlayed with the 
specific parameters in Table 16-22. 


Table 16-22. Single-Buffer Mode Parameter RAM Map 


j—roonese | te | om DESTINATION ADDRESS GENERATION MODE 
ADDRESS WIDTH 

| DMABase+00 | BAPR* | Word | — Buffer Address Pointer | Current Buffer Address Pointer 
aa = 


NOTE: You are only responsible for initializing the items in bold. 
* = Modified by the IDMA controller during operation and should be reinitialized before starting a new IDMA transaction. 
DMA base = (IMMR & OxFFFF0000) + 0x3CCO (IDMA1). 
All references to registers in the parameter RAM table are actually implemented in the dual-port RAM area as 
a memory-based register. 
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You must initialize the parameter RAM values before the channel is enabled. However, they 
should only be modified when there is no DMA activity. 


¢ Buffer Address Pointer—The buffer address pointer contains 32 address bits of the 
destination buffer address used by the IDMA. The BAPR should be programmed to 
burst-aligned address. In progressive mode, the BAPR is incremented by 16 bytes after 
each transfer and it is incremented by 16 for each burst. In interlaced mode the BAPR 
is incremented by 16 for each burst while it is within a line and then it is incremented by 
the RBR to point to the next line. 


e Byte Count Register—The 32-bit byte count register specifies the number of bytes to 
be transferred by the IDMA. The BCR is decremented by 16 byies after each transfer 
and must be programmed as a multiple of 16. In progressive mode, the IDMA channel 
will terminate the transfer of a block of data if this register reaches zero during 
operation. 


¢ DMA Channel Mode Register—The 32-bit DMA channel mode register controls the 
channel operation mode. 


Sos 
SESE 


MB1 | RESERVED 








RESERVED 


(IMMR & OxFFFF0000) + 0x3CCA 





MB1—Must Be 1 
For DMA operation, this bit must be set to 1. 


Bits 1, 2, 9-11, 16~-31—Reserved 
These bits are reserved and should be set to 0. 
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BO—Byte Ordering : 

You should set this field to select the required byte ordering of the for the data buffer. 
lf this field is modified on-the-fly, it will take effect at ne beginning of the next buffer 
descriptor. 


00 = DEC/Intel convention is used for byte ordering (swapped operation). It is also 
called little-endian byte ordering. The transmission order of bytes within a buffer 
word is reversed as compared to the Motorola mode. This mode is supported only 
for 32-bit port size memory. 

01 = PowerPC little-endian byte ordering. As data is ianemitteds onto the serial line 
from the data buffer, the least significant byte of the buffer double-word contains 
data to be transmitted earlier than the most significant byte of the same pact 
double word. 

1X = Motorola byte ordering (normal operation). It is also called big-endian byte 
ordering. As data is transmitted onto the serial line from the data buffer, the most 
significant byte of the buffer word contains data to be transmitted earlier than the 
least significant byte of the same buffer word. 


ATt—Address Type 1-3 

This field contains the function code value used during this SDMA channel memory 
access. ATO will be driven with a one to identify this SDMA channel access as a 
DMA-type access. 


STR—Start | | oe ae 
This bit enables the IDMA channel. You should set it after you program BAPR and 

BCR. It is cleared by the channel upon emotion of the transier and the one count in 

BCR is exhausted. 7 


O0O= DMAchannel ts disabled. | 
1= DMAchannel is enabled. 


EDGE—Edge-Sensitive DREQ1 


This bit controls whether the CPM will be interlocked to the acid SDACK1 signal 
before exiting the IDMA routine. This bit must be cleared if level-sensitive DREQ1 is 
used. If the DR1M bit of the RCCR is set to 1, this bit must be set to 0. 





O= Level-sensitive mode. The CPM will wait until SDACK1 is seen siiemally before 
executing the IDMA routine. 

1= Edge-sensitive mode. The CPM may exit the IDMA routine before SDACK1 is 
seen externally. 


ITLC—Interlaced Mode 
This bit controls the destination address bit generation. 


O= Progressive (non- interlaced) address generation. 
1= Interlaced address generation. 
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BPR—Bursts Per Request 
This field determines how many bursts will be transferred per ee 


00 = = One pte! per aise 
01 = Two burst per request. 
10= Reserved.’ 

11 = Four bursts per request. 


¢ Field Base Address Register—This 32-bit register specifies the field destination base 
address. FBAR is incremented by the number of bytes per line after each field. It is used 
in interlaced mode only. : 


° Number of Fields Per Frame Register—This 16-bit register specifies the number of field 
per frame. It is used in interlaced mode only. NFLD is decremented after each field. 


e Lines Per Field Count Register —This 16-bit register specifies the number of lines per 
field. It is used in interlaced mode only. . 7 


¢ Lines Per Field Register—This 16-bit register specifies the number of remaining lines 
to the end of the field. It is used in interlaced mode only, and should be initialized to the 
value of the LCR. L_CNT is decremented after each line. 


¢ Bytes Per Line Register—This 16-bit register specifies the number of bytes p per line. The 
value must be divisible by 16 for one burst per request, by 32 for two bursts per request, 
or by 64 for four bursts per request. It is used in interlaced mode only. 


e Raw Bytes Register—This 16-bit register specifies the number of bytes to skip from the 
end of one line to the beginning of the next line. It is used in interlaced mode only. 


16.6.3.12 IDMA STATUS REGISTER. The 8-bit IDMA status register (IDSR) is used to 
report evenis recognized by the IDMA controller. When an event is recognized, the IDMA 
controller sets the corresponding bit in the IDSR. This memory-mapped register can be read 
at any time. A bit is reset by writing a one (writing a zero has no effect). 


IDSR 





(IMMR & OxFFFF0000) + 0x910 (IDSR1), 0x918 (IDSR2) 


Bits O—5 and 7—Reserved 
These bits are reserved and should be set to 0. 


DONE—IDMA Transfer Done 


This bit indicates that the IDMA channel terminated a uaneler It will be set after the byte 
count in BCR has reached zero. 
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16.6.3.13 IDMA MASK REGISTER. The 8-bit read/write IDMA mask register (IDMR) has 
the same bit format as the IDMA status register. If a bit in this register is a one, the 
corresponding interrupt in the IDSR will be enabled. If the bit is zero, the corresponding 
interrupt in the IDSR will be masked. 


IDMR 





(IMMR & OxFFFF0000) + 0x914 (IDMR1), 0x91C (IDMR2) 


Bits O-5 and 7—Reserved 
These bits are reserved and should be set to 0. 


DONE—IDMA Transfer Done 


This bit indicates when the IDMA channel terminates a transfer. It is set after servicing a 
buffer descriptor that has the L bit set. : | 


16.6.3.14 SINGLE-BUFFER TIMING. A typical single-address burst timing when the IDMA 
is in single-buffer mode, is illustrated in Figure 16-42. The peripheral device asserts the 
DREQ?1 pin and waits for SDACK71 to initiate a burst transfer to or from memory. The 
peripheral must negate the DREQ1 pin before the last beat of the transfer. Otherwise, IDMA 
will assume that another DMA request is pending and will start another burst cycle right after 
the completion of the current transfer. 
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Figure 16-42. IDMA Single-Address Burst Read or Write 


16.6.3.15 DOWNLOAD SEQUENCE. The microcode package is provided in S-records 
format. It occupies the first 512 bytes of the dual-port RAM (on the ADS address 0x2202000 
to address 0x22021FF) and 256 bytes at the end of the first 4K (on the ADS address 
0x2202F00 to address 0x2202FFF). For MPC823 silicon versions 0.3 (Z3, mask number 
3F98S) and later, you do not need to download this microcode. Use the following MPC8bug 
debugger commands to load the package: 


rms cpm recr 0 
load interlaced_dma.srx 
rms cpm recr 9 
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16.6.3.16 BUS EXCEPTIONS. When IDMA has the bus and is performing operand 
transfers, bus exceptions can occur. When a synchronous bus structure like those 
supported by the MPC823 is used, you can make provisions that allow a bus master to 
detect and respond to errors during a bus cycle. IDMA recognizes the same bus exceptions 
that the core recognizes at reset or when a transfer error occurs. 


e Reset—On an external reset, IDMA immediately aborts channel operation, returns to 
the idle state, and clears the IDSR. If a bus cycle is in progress when reset is detected, 
the cycle is terminated, the control and address/data pins are three-stated, and bus 
ownership is released. 


e Transfer error—When a fatal error occurs during a bus cycle, a bus error exception is 
used to abort the cycle and systematically terminate that channel operation. The IDMA 
terminates the current bus cycle, signals an error in the SDSR, and signals an interrupt 
if the corresponding bit in the SDMR is set. IDMA waits for the RISC microcontroller to 
reset before starting any new bus cycles. It should be noted that any data previously 
read from the source into the internal storage is lost. 


Note: Any device that is the source or destination of the operand under IDMA 
handshake control for single address transfers may need to monitor TEA to 
detect a bus exception for the current bus cycle. TEA terminates the cycle 
immediately and negates SDACKx, which is used to control the transfer to or 
from the device. 





16.7 THE SERIAL INTERFACE WITH TIME-SLOT ASSIGNER 


The serial interface connects the physical layer serial lines to the serial communication 
controller and two serial management controllers. In its simplest configuration, the serial 
interface allows these controllers to be connected to their own set of individual pins. The 
serial communication controller or serial management controller that connects to the 
external world in this way connects to a nonmultiplexed serial interface (NMSI). In an NMSI 
configuration, the serial interface provides a flexible clocking assignment for the serial 
communication controller or serial management controller from a bank of external clock pins 
and/or internal baud rate generators. 


However, the main feature of the serial interface is its time-slot assigner (TSA), which allows 
any combination of the serial communication or management controllers to multiplex their 
data together on one or one time-division multiplexed (TDM) channel. Common examples 
of TDMs are the T11 lines in the U.S. or Japan and the CEPT lines in Europe. Even if the 
time-slot assigner is not used in its intended capacity, it can still be used to generate 
complex waveforms on four output pins. For example, these pins can be programmed by 
the time-slot assigner to implement stepper motor control or variable duty cycle and period 
control on these pins. Any programmed configuration can be changed on-the-fly. The serial 
interface block diagram is illustrated in Figure 16-43. 
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NONMULTIPLEXED SERIAL INTERFACE (NMSI) 


Figure 16-43. Serial Interface Block Diagram 
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16.7.1 Features 


The top-level features of the serial interface are the time-slot assigner and NMSI. The 
time-slot assigner has the following main features: 


e Ability to connect to an independent TDMA channel 

e Independent, programmable transmit and receive routing paths 

e Independent transmit and receive frame syncs 

e Independent transmit and receive clocks 

¢ Selection of rising/falling clock edges for the frame sync and data bits 
° Supports 1x and 2x input clocks (1 or 2 clocks per data bit) 

° Selectable delay (0-3 bits) between frame sync and frame start 


e Eight programmable strobe outputs (LST[1-4] used for receive (RX) RAM while 
LST[5-8] is used for transmit (TX) RAM) 


° 1- or 8-bit resolution in routing, masking, and strobe selection 
¢ Supports frames up to 8,192 bits long | | os 


Mf 


e Internal routing and strobe selection can be dynamically programmed , eee 
e Supports automatic echo and loopback mode for the TDMA 


The NMSI has the following main features: 


¢ The serial communication controller (GCC2) and each serial management controller 
(SMC) can be independently programmed to work with its own set of pins ina 
nonmultiplexed manner 


e The serial communication controller can have its own set of modem control pins 
e Each serial management controller can have its own set of pins 


e The serial communication controller, universal serial bus, and each serial management 
controller can derive clocks externally from a bank of four clock pins or a bank of four 
baud rate generators 


16.7.2 Configuring the Time-Slot Assigner 


The time-slot assigner implements both internal route selection and time-division 
multiplexing for multiplexed serial channels. It supports the serial bus rate and format for 
most standard TDM buses, including the T1 and CEPT highways, pulse code modulation 
(PCM) highway, and ISDN buses in both basic and primary rates. The two popular ISDN 
basic rate buses—interchip digital link and general circuit interface (also known as IOM-2) 
are supported. 
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Time-slot assigner programming is completely independent of the protocol used by the 
serial communication controller or serial management controller. For instance, the fact that 
SCC2 can be programmed for the HDLC protocol has no impact on time-slot assigner 
programming. The purpose of the time-slot assigner is to route the data from the specified 
pins to the serial communication controller or serial management controller at the correct 
time, but it is the responsibility of the SCC2 or SMC to handle the received data. In its 
simplest mode, the time-slot assigner identifies the frame using one sync pulse and one 
clock signal that you provide. This can be enhanced to allow independent routing of the 
receive and transmit data on the TDMA channel. Additionally, the definition of a time-slot 
need not be limited to 8 bits or even to a single contiguous position within the frame. You 
can provide separate receive and transmit syncs as well as clocks. These various 
configurations are illustrated in Figure 16-44. 


The time-slot assigner can support two, independent, half-duplex TDMA sources, one in 
reception and one in transmission, using two sync inputs and two input clocks. In addition 
to channel programming, the time-slot assigner supports up to eight strobe outputs that may 
be asserted on a bit or byte basis. These strobes are completely independent from the 
channel routing used by SCC2 and the SMCs. They are useful for interfacing to other 
devices that do not support the multiplexed interface or for enabling/disabling three-state 
I/O buffers in a multi-transmitter architecture. 


Most time-slot assigner programming is accomplished in two 64 x 16-bit serial interface 
RAMs that are directly accessible by the host CPU in the internal register section of the 
MPC823 and are not associated with the dual-port RAM. One serial interface RAM is always 
used to program the transmit routing and the other is used to program the receive routing. 
With the serial interface RAMs, you can define the number of bits or bytes to be routed to 
the serial communication controller or serial management controller and decide when the 
external strobes are to be asserted and negated. 


The size of the serial interface RAM that is available for time-slot programming depends on 
the configuration of the RDM field in the SIGMR. If on-the-fly changes are allowed, the serial 
interface RAM entries are reduced by one-half. However, the serial interface RAM size is 
sufficient to allow extensive time-slot programming flexibility. The maximum frame length 
that can be supported in any configuration is 8,192 bits. The serial interface supports two 
testing modes—echo and loopback. The echo mode provides a return signal from the 
physical interface by eeneminng the signal it has received. 


The physical interface echo mode differs from the individual SsCC2 echo mode in that it can 
operate on the entire TDM signal, rather than just on a particular SCC2 channel. The 
loopback mode causes the physical interface to receive the same signal it is transmitting. 
The serial interface loopback mode checks more than the individual SCC2 loopback does. 
It checks the serial interface and the internal channel routes. The maximum external serial 
clock that may be an input to the time-slot assigner is GCLK2 + 2.5. Ifa serial communication 
controller or serial management controller is operating with the NMSI, then the serial clock — 
rate may be slightly faster at a value not to exceed GCLK2 + 2. 
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Simplest TDM Example 


MECHed 1TDM SYNC | | | 
tom crock {ILL PULT ULL] 


SCC2 SMC1 
tomtx | | fsuors] story 
tomex | | fsiors} story 


SCC2 SMC1 
More Complex TDM Example—Unique Routing 


MPC823 | | 
1TDM SYNC 


SCC2 SMC1 
[Jaen Jason 


SCC2 SMC1 
Even More Complex TDM Example—Multiple Time-Slots per Channel with Varying Sizes of Time-Slots 


MPC823 1 TDM SYNC | | 


TSA TDM 





TSA TDM 


TDM RX 





SCC2 SMC1 SCC2 


TSA|“<—_> TDM 





SCC2 SMC1 SCC2 


NOTE: The two shaded areas of SCC2 RX are received as one high-speed datastream by the SCC2 and stored 
together in the same data buffers. 


Most Complex TDM Example—Totally Independent RX and TX 


MPC823 | 
TDM TX SYNC | | 


TSA\< > TDM SCC2 SMC1 SCC2 


TDM TX 


TDM RX SYNC ee ee lace ee ee 
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Figure 16-44. Various Configurations With the TDM Channel 
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16.7.3 Enabling Connections to the Time-Slot Assigner 


Each serial communication controller and serial management controller can be 
independently enabled to connect to the time-slot assigner. SCC2 is connected to the 
time-slot assigner by setting the SC2 bit in the SICR. The serial management controllers are 
connected to the time-slot assigner by setting the SMCx field of the SIMODE register. 
Additionally, the TDMA interface must be enabled before it can be connected to the time-slot 
assigner by setting the ENA field in the SIGMR. Once the connections are made, the exact 
routing decisions are made in the serial interface RAM. Refer to Figure 16-45 for more 
information. 


ENA = 1 TO ENABLE 





_ MULTIPLEXED 
TDMA P INS | INTERFACE 


SCC2 : = SCC2 PINS 
| : a: | 
. : =|. 
7p) = : 
SMC1 7 SMC1 PINS 


NONMULTIPLEXED 
INTERFACE 


Figure 16-45. Enabling Connections Through the Serial Interface 


16.7.4 Serial Interface RAM Operation 


The serial interface has two 64 x 16 static RAMs that are used to cenit the Sein of the 
TDMA channel to the serial communication and management controllers. These RAMs are 
uninitialized after power-on and, to avoid unwanted results, the host CPU should program 
them before enabling the multiplexed channels. The RAMs consist of 16-bit entries that 
define the routing control and each entry can control anywhere from 1 to 16 bits or 1 to 16 
bytes. In addition to the routing, up to four strobe pins i active high) can be asserted, 
depending on how the RAM | Is Plool amet: 


You can configure the serial interface RAM in the following formats to support the TDMA 
channel: : , 


¢ One multiplexed channel with static frames 
¢ One multiplexed channel with dynamic frames 
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16.7.4.1 ONE MULTIPLEXED CHANNEL WITH STATIC FRAMES. In this configuration, 
there are 64 entries in the serial interface RAM for transmit data and strobe routing and — 
64 entries for receive data and strobe routing. This configuration should be chosen when the 
one time-division multiplex’s routing does not need to be dynamically changed. 









RDM = 00 
ONE CHANNEL WITH INDEPENDENT RX AND TX ROUTE 
FRAMING SIGNALS 
SERIAL INTERFACE RAM ADDRESS 0 
(16 BITS WIDE) LIRCLKA 
LIRSYNCA 
64 ENTRIES 
127 
i LITCLKA ( ah 
LITSYNCA ia 


64 ENTRIES 
TXA 
ROUTE 






206 


Figure 16-46. Configuring the TDM with Static Frames 


16.7.4.2 ONE MULTIPLEXED CHANNEL WITH DYNAMIC FRAMES. In this 
configuration, there is one multiplexed channel and it has 32 entries for transmit data and 

strobe routing and 32 entries for receive data and strobe routing. In each RAM, one of the 
partitions is the current-route RAM and the other is a shadow RAM that allows you to change 
the serial routing. After programming the shadow RAM, set the CSRRA bit of the associated 
channel in the SIMCR to receive and the CSRTA bit to transmit. When the next frame sync 
arrives, the serial interface automatically exchanges the current-route RAM for the shadow 
RAM. Refer to Section 16.7.4.4 Serial Interface RAM Dynamic Changes for more details 
on how to dynamically change the channel route. You should only use this configuration 
when the routing on the time-division multiplex needs to be dynamically changed. 
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RDM = 01 
ONE CHANNEL WITH SHADOW RAM FOR DYNAMIC ROUTE CHANGE 


FRAMING SIGNALS 





SERIAL INTERFACE RAM ADDRESS 0 


(16 BITS WIDE) 
LIRCLKA 
32 ENTRIES LIRSYNCA 
RXA 
ROUTE 
63 
128 
LITCLKA 
32ENTRIES He LITSYNCA 


TXA 
ROUTE 


191 





Figure 16-47. Configuring the TDM with Dynamic Frames 


16.7.4.3 PROGRAMMING THE SERIAL INTERFACE RAM ENTRIES. The programming 
of each word within the RAM determines the routing of the serial bits and assertion of strobe 
outputs. The RAM programming codes are shown in the following table. 


SERIAL INTERFACE RAM ENTRIES 


BSEUN DON 


LOOP | SWTR | SSEL1 | SSEL2 | SSEL3 SseLt| RES | CSEL 


RESERVED | 


EXESEVESESESELESES ED 
R/W 


(IMMR & OxFFFF0000) + 0xC00 TO OxDFF 





LOOP—Loopback on This Time-Slot 


Normal mode. 
Loopback mode for this time-slot. 
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SWTR—Switch Transmit and Receive 


This bit is only valid in the receive route RAM and is ignored in the transmit route RAM. This 
bit affects the operation of both the L1RXDA and L1TXDA pins. The SWTR bit is only set in 
special situations where you prefer to receive data from a transmit pin and transmit data on 
a receive pin. For instance, consider the situation where devices A and B are connected to 
the same time-division multiplex, each with different time-slots. Normally, there is no 
opportunity for stations A and B to communicate with each other directly over the 
time-division multiplex since they both receive the same TDM receive data and transmit on 
the same TDM transmit signal. 


TDM RECEIVE DATA 





TDM TRANSMIT DATA 






RX TX 










STATION A STATION B 





Figure 16-48. Using the SWTR Bit 


The SWTR option gives station B the opportunity to listen to transmissions from station A 
and transmit data to station A. To do this, station B would set the SWTR bit in its receive 
route RAM. For this entry, receive data is taken from the L1TXDA pin and data is transmitted 
on the L1RXDA pin. If you only want to listen to station A transmissions and not transmit 
data on L1RXDA, then you should clear the CSEL field in the corresponding transmit route 
RAM entry to prevent transmission on the L1RXDA pin. | 


It is also possible for station B to transmit data to station A by setting the SWTR bit of the 
entry in its receive route RAM. Data is transmitted on the L1RXDA pin rather than the 
L1TXDA pin, according to the transmit route RAM. This configuration could, however, cause 
collisions with other data on the L1RXDA pin unless care is taken to choose an available 
(quiet) time-slot. If you only want to transmit on L1RXDA and not receive data on L1TXDA, 
then you should clear the CSEL field in the receive route RAM to prevent reception of data 
on L1TXDA. 


O = Normal operation of the L1TXDA and L1RXDA pins. 
1 = Data is transmitted on the L1RXDA pin and is received from the L1TXDA pin for 
the duration of this entry. 


| “Oo Note: Ifthe transmit and receive sections of the TDMA do not use a single clock source, 
| the SWTR feature can cause erratic results to occur. 
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SSEL1—SSEL4—Strobe Select 1—4 


The four strobes—L1ST1, L1ST2, L1ST3, and L1 ST4—can be assigned to the receive RAM 
and asserted or negated with L1RCLKA. L1ST5, L1ST6, L1ST7, and L1ST8 can be 
assigned to the transmit RAM and asserted or negated with L1TCLKA. Each bit corresponds 
to the value the strobe should have during this bit/byte group. Multiple strobes can be 
asserted simultaneously, if preferred. If a strobe is configured to be asserted in two 
consecutive serial interface RAM entries, then it remains continuously asserted while the 
serial interface RAM entries are being processed. If a strobe is asserted on the last entry in 
the table, the strobe is negated after the last entry finishes processing. 


Note: Each strobe is changed with the corresponding RAM clock and is only output if 
the corresponding parallel |/O is configured as a dedicated pin. 


Bit 6—Reserved 
This bit is reserved and should be set to 0. 


CSEL—Channel Select 


000 = The bit/byte group is not supported by the MPC823. The transmit data pin is 
three-stated and the receive data pin is ignored. 

001 = Reserved. 

010 = The bit/byte group is routed to SCC2. 

011 = Reserved. 

100 = Reserved. | | 

101 = The bit/byte group is routed to SMC1. 

110 = The bit/byte group is routed to SMC2. 

111 = The bit/byte group is not supported by the MPC823. This code is also used 
in the SCIT mode as the D channel grant. 


CNT—Count 


This value indicates the number of bits/bytes (according to. the BYT bit) that the routing and. 
strobe select of this entry controls. If CNT = 0000, then 1 bit/byte is chosen and if 
CNT = 1111 16 bits/bytes are selected. 


BYT—Byte Resolution 


O= Bit resolution. The value of CNT indicates the number of bits in this group. 
1 = Byte resolution. The value of CNT indicates the number of bytes in this group. 
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LST—Last Entry in the RAM 
Whenever the serial interface RAM is used, this bit must be set in one of the TX or RX entries 
of each group. Even if all entries of a group are used, this bit must still be set in the last entry. 


0 = This is not the last entry in this section of the route RAM. 
1 = This is the last entry in this RAM. After this entry, the serial interface waits for the 
sync signal to start the next frame. 


3 “Oo Note: If asecond sync signal is received before the end of a frame (as defined by the 
| last serial interface RAM entry), an error occurs. The serial interface will 
terminate RAM processing and cease transmitting or receiving data until a third 

sync signal is received. 


16.7.4.4 SERIAL INTERFACE RAM DYNAMIC CHANGES. The serial interface RAM has 
two operating modes: 


e A time-division mulitplex channel with a static routing definition. The serial interface — = = 
RAM is divided into two parts (RX and TX). | Ne aes 
e A time-division mulitplex channel that allows Snane changes. The serial interface 
RAM is divided into four parts. 


Dynamic changes allow the routing definition of a TDMA to be modified while the serial 
communication controller and serial management controllers are connected to it. With fixed 
routing, a change has three requirements that must be met before the new routing takes 


effect: 


e The serial communication controller and serial management controllers connected to 
the time-slot assigner must be disabled. 


e The serial interface routing must be modified. 


e The serial communication controller and serial management controllers connected to 
the time-slot assigner must be reenabled. 


Dynamic changes divide portions of the serial interface RAM into current-route and shadow 
RAM. Once the current-route RAM is programmed, the time-slot assigner and serial 
interface channels are enabled and time-slot assigner operation begins. When you need to 
make a change in routing, you must program the shadow RAM with the new route and set 
the CSRRA bit in the SIMCR to receive and the CSRTA bit to transmit. As a result, the serial 
interface exchanges the shadow RAM and the current-route RAM as soon as the 
corresponding sync arrives and resets the appropriate CSRxA bit to signify that the 
operation has completed. At this time, you can change the routing again. Notice that the 
original current-route RAM is now the shadow RAM and vice versa. Figure 16-49 illustrates 
an example of the shadow RAM exchange process. 
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Ifa TDMA with dynamic changes Is programmed, the initial current-route RAM addresses in 
the serial interface RAM are as follows: 


¢ 0-63 RXa Route 
e 128-191 TXa Route 


The shadow RAMs are at addresses: 


e 64-127 RXa Route 
e 192-255 TXa Route 


You can read any RAM at any time, but for proper serial interface operation you must not try 
to write the current-route RAM. You can, however, read the serial interface status register 
(SISTR) to find out which part of the RAM is the current-route RAM. 


Besides knowing which RAM is the current-route RAM, you might need to know which entry 
the time-slot assigner is currently using within the current-route RAM. This information is 
provided in the SIRP register, which is described in detail in Section 16.7.5.6 Serial 
Interface RAM Pointer Register. You can also externally connect one of the eight strobes 
to an interrupt pin to generate an interrupt on a particular serial interface RAM entry starting 
or ending execution by the time-slot assigner. _ 
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1) INITIAL STATE RAM ADDRESS: 0 63 __64 127 


THE TSA USES THE FIRST PART OF 
THE RAM, AND THE SHADOW IS 
THE SECOND PART OF THE RAM. 

















CSRXN = 0 LIRCLKA 
FRAMING SIGNALS: LIRSYNCA 
CSRRA=0 RAM ADDRESS: 128 191 192 255 
CSRTA=0 : 
LITCLKA 
FRAMING SIGNALS: LITSYNCA 
1) PROGRAMMING RAM ADDRESS: 0 63 64 127 
PROGRAM THE 
SHADOW RAM FOR THE NEW 
RX AND TX ROUTE AND SETS 
CSRXN. LIRCLKA 
FRAMING SIGNALS: LIRSYNCA 
CSRRA=1 RAM ADDRESS: 128 191 192 255 
CSRTA=1 
LITCLKA 
FRAMING SIGNALS: LITSYNCA 
EXCHANGE | RAM ADDRESS: 0 63 64 127 
THE SERIAL ENTERFACE 
EXCHANGES BETWEEN 
THE SHADOW AND THE 
CURRENT-ROUTE RAMS arg ection 
CSRRA=0 RAMADDRESS: 128 191 192 255 
CSRTA=0 





LITCLKA 
FRAMING SIGNALS: . LITSYNCA 


Figure 16-49. Serial Interface RAM Dynamic Changes 
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16.7.5 Serial Interface Programming Model 


16.7.5.1 SERIAL INTERFACE GLOBAL MODE REGISTER. The 8-bit, memory-mapped, 
read/write serial interface global mode register (SIGMR) defines the RAM division modes. 


SIGMR 


(IMMR & OxFFFFO000) + OxAE4 





Bits O-4—Reserved 
These bits are reserved and should be set to 0. 


ENA—Enable Channel A 


0 = Channel A is disabled. The serial interface RAMs and TDMA routing are in a state 
of reset, but all other serial interface functions still operate. 
1 = The serial interface is enabled. | 


RDM—RAM Division Mode 


This field defines the RAM division mode and the number of multiplexed channels supported 
in the serial interface. 


00 = The serial interface supports one TDMA channel with 64 entries for receive 
routing and another 64 for transmit routing. 

01 = The serial interface supports one TDMA channel with 32 entries for receive 
routing and another 32 for transmit routing. There are an additional 32 shadow 
entries for the receive routing and 32 more for transmit routing that can be used 
to dynamically change the routing. 


1x = Reserved. 
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16.7.5.2 SERIAL INTERFACE MODE REGISTER. The 32-bit, memory-mapped, 
read/write serial interface mode register (SIMODE) defines the serial interface operation 
modes and with serial interface RAM allows you to support any or all of the ISDN channels 
independently when in IDL or GCI mode. 


SIMODE 


SMC2CS RESERVED 


(IMMR & OxFFFFO000) + OxAEO 





SMC2—SMC2 Connection 


O = NMSI mode. The clock source is determined by the SMC2CS field and the data 
comes from a dedicated SMTXD2 and SMRXD2 pin in NMSI mode. 
= SMC2 is connected to the multiplexed serial interface (TDMA channel). 


SMC2CS—SMC2 Clock Source (NMSI mode) 


SMC2 can take its clocks from one of the baud rate generators or one of four pins from the 
bank of clocks. However, the SMC2 transmit and receive clocks must be the same when 
they are connected to NMSI mode. 


000 = SMC2 transmit and receive clocks are BRG1. 
001 = SMC2 transmit and receive clocks are BRG2. 
010 = SMC2 transmit and receive clocks are BRG3. 
011 = SMC2 transmit and receive clocks are BRG4. 
100 = SMC2 transmit and receive clocks are CLK1. 
101 = SMC2 transmit and receive clocks are CLK2. 
110 = SMC2 transmit and receive clocks are CLKS. 
111 = SMC2 transmit and receive clocks are CLK4. 


SMC1—SMC1 Connection 


0 = NMSI mode. The clock source is determined by the SMC1CS field and the data 
comes from a dedicated pin SMTXD1 and SMRXD1 in NMS! mode. 
= SMC1 is connected to the multiplexed serial interface (TDMA channel). 
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SMC1CS—SMC1 Clock Source (NMSI mode) 


SMC1 can take its clocks from one of the baud rate generators or one of four pins from the 
bank of clocks. The SMC1 transmit and receive clocks must be the same when it is 
connected to the NMSI. | 


000 = SMC1 transmit and receive clocks are BRG1. 
001 = SMC1 transmit and receive clocks are BRG2. 
010 = SMC1 transmit and receive clocks are BRGS. 
011 = SMC1 transmit and receive clocks are BRG4. 
100 = SMC1 transmit and receive clocks are CLK1. 
101 = SMC1 transmit and receive clocks are CLK2. 
110 = SMC1 transmit and receive clocks are CLK3. 
111 = SMC1 transmit and receive clocks are CLK4. 


SDMA—Serial Interface Diagnostic Mode for TDMA 


OO = Normal operation. 

01 = Automatic echo. In this mode, the channel transmitter automatically retransmits 
the data received from the TDMA on a bit-by-bit basis. The receive section 
operates normally, but the transmit section can only retransmit received data. In 
this mode, the L1GRA signal is ignored. 

10 = Internal loopback. In this mode, the TDMA transmitter output is internally 
connected to the TDMA receiver input.(L1TXDA is connected to L1RXDA). The 
receiver and transmitter operate normally. The data appears on the L1TXDA pin. 
In this mode the L1RQA signal is asserted normally. The L1GRA signal is ignored. 

11 = Loopback control. In this mode, the TDMA transmitter output is internally 
connected to the TDMA receiver input (L1TXDA is connected to L1RXDA). The 
transmitter output (L1TXDA) and the L1RQA pin is inactive. This mode is used to 
accomplish loopback eng of the entire TDMA without affecting the external 
serial lines. 


Note: In modes 01 ,10, and 11, the receive and transmit clocks should be identical. 





RFSDA—Receive Frame Sync Delay for TDMA 


This field determines the number of clock delays between the receive sync and the first bit 
of the receive frame. Even if the CRTA bit is set, these bits do not control the delay for the 
transmit frame. 


00 = No bit delay. The first bit of the frame is transmitted/received on the same clock 
as the sync. Use for GCI. 

01 = 1-bit delay. Use for IDL. 

10 = 2-bit delay. 

11 = 3-bit delay. 


see the examples in Figure 16-50 and Figure 16-51 to find out how to use these bits. 
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DSCA—Double Speed Clock for TDMA 
This bit controls how some time-division multiplex channels, such as GCI, define the input 
clock to be two times faster than the data rate. 


O= The channel clock (L1RCOLKA and/or L1TCLKA) is equal to the data clock. Use for 
IDL and most TDM formats. 
1 = The channel clock rate is twice the data rate. Use for GCI. 


CRTA—Common Receive and Transmit Pins for TDMA 

This bit is useful when the transmit and receive sections of a given TDMA use the same 
clock and sync signals. In this mode, the L1TCLKA and L1TSYNCA pins can be used as 
general-purpose I/O pins. 


= Separate pins. The receive section of this TDMA uses L1RCLKA and L1 RSYNCA 
pins for framing and the transmit section uses L1TCLKA and L1TSYNCA for 
framing. 
1 = Common pins. The receive and transmit sections of this TDMA use L1 RCLKA as 
clock pin of the channel and L1RSYNCA as the receive and transmit sync pin. Use | 
for IDL and GCI. \ 


iF VPqVANL 


STZA—Set L1TXDA to Zero for TDMA 
O= Normal operation. 
1 = L1TXDA is set to zero until serial clocks are available, which is useful for GCI 
activation. 


CEA—Clock Edge for TDMA 
0 = Data is transmitted on the rising edge of the clock and received on the falling edge 


(use for IDL and GCl). 
1 = Data is transmitted on the falling edge of the clock and received on the rising edge. 


FEA—Frame Sync Edge for TDMA 
This bit indicates when the L1RSYNCA and L1TSYNCA pulses are sampled with the falling 
or rising edge of the channel clock. 


0= Falling edge. Use for IDL and GCI. 
1 = Rising edge. 


GMA—Grant Mode for TDMA 

0= GCI/SCIT mode. The GCI/SCIT D channel grant mechanism for transmission is 
internally supported. The grant is one bit from the receive channel. This bit is 
marked by programming the channel select bits of the serial interface RAM with 
111 to assert an internal strobe on it. See Section 16.7.7.2.2 SCIT Mode. 

1 = IDL mode. A grant mechanism is supported if the corresponding GR2 bit in the 
SICR register is set. The grant is a sample of the L1GRA pin while L1TSYNCA is 
asserted. This grant mechanism implies the IDL access controls for transmission 
on the D channel. Refer to Section 16.7.6.2 Programming the IDL Interface for 
more information. 
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TFSDA—Transmit Frame Sync Delay for TDMA 


This field determines the number of clock delays between the transmit sync and the first bit 
of the transmit frame. | 


00 = No bit delay. The first bit of the frame is transmitted/received on the same clock 
as the sync. 


01 = 1-bit delay. 
10 = 2-bit delay. 
11 = 3-bit delay. 


LICLK 


(FE=1) uJ | 


DATA 









———— 


END OF FRAME 
: ZY ato 





ONE CLOCK DELAY FROM SYNC LATCH TO FIRST BIT OF FRAME 


Figure 16-50. Example of One Clock Delay from Sync to Data (RFSD = 01) 





LiCLK ar a 
(CE=0) , a 


LISYNC 
(FE=1) 


DATA 





Figure 16-51. Example of No Delay from Sync to Data (RFSD = 00) 
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CE=0 


LICLK 


LiSYNC 


LISYNC 





LITXDA (BIT 0) 


L1ST (ON BIT 0) 


- 


\ 
\ RX SAMPLED HERE 


Figure 16-52. Example of Clock Edge (CE) Effect When DSC = 0 





CE=1 | | FSD=1 


LICLK 


LISYNC 


LISYNC 


LITXDA (BIT 0) 


LIST (ON BIT 0) TH FE SETTINGS | 


'\ RX SAMPLED HERE 


Ww ae ee 


Figure 16-53. Example of Clock Edge (CE) Effect When DSC = 1. 
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CE=0 FSD=0 


LICLK 


LISYNC (FE=1) 
LITXDA (BIT 0) 


L1ST (ON BIT 0) 


LiSYNC (FE=1) 





LITXDA (BIT 0) 


LiST (ON BIT 0) 


LISYNC 


L1TXDA (BIT 0) 


L1ST (ON BIT 0) 


LISYNC 


L1TXDA (BIT 0) 


LiST (ON BIT 0) 





Figure 16-55. Example of CEx = 0 and FEx Interaction, XFSD = 0 
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16.7.5.3 SERIAL INTERFACE CLOCK ROUTE REGISTER. The 32-bit, read/write, 
memory-mapped serial interface clock route (SICR) register is used to define the universal 
serial bus and serial communication controller clock sources that can be one of the four 
baud rate generators or an input from a bank of clock pins. 


SICR 


RESERVED 





(IMMR & OxFFFFO000) + OxAEE 


Bits 0O—-15—Reserved 
These bits are reserved and should be set to 0. 


GR2—Grant Support of SCC2 


0= SCC2 transmitter does not support the grant mechanism. The grant is always 
asserted internally. 
= SCC2 transmitter supports the grant mechanism as determined by the GMA bit 
of the SIMODE register. 


SC2—SCC2 Connection 


0= SCC2 is not connected to the multiplexed serial interface but is either connected 
directly to the NMSI2 pins or is not used. You can choose either the 
general-purpose I/O port pins or dedicated SCC2 pins in the parallel I/O port 
registers. See Section 16.14 The Parallel I/O Ports for more information. 
= SCC2 is connected to the multiplexed serial interface. The NMSI2 receive pins are 
available for other purposes. 
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R2CS—Receive Clock Source for SCC2 
This field is ignored when the SCC2 is connected to the time-slot assigner (SC2 = 1). 


000 = SCC2 receive clock is BRG1. 
001 = SCC2 receive clock is BRG2. 
010 = SCC2 receive clock is BRG3. 
011 = SCC2 receive clock is BRG4. 
100 = SCC2 receive clock is CLK1. 
101 = SCC2 receive clock is CLK2 . 
110 = SCC2 receive clock is CLK3 . 
111 = SCC2 receive clock is CLK4 . 


T2CS—Transmit Clock Source for SCC2 
This field is ignored when SCC2 is connected to the time-slot assigner (SC2 = 1). 


000 = SCC2 transmit clock is BRG1. 

001 = SCC2 transmit clock is BRG2. 7 

010 = SCC2 transmit clock is BRG3. 7 an 
011 = SCC2 transmit clock is BRG4. | 
100 = SCC2 transmit clock is CLK1. 
101 = SCC2 transmit clock is CLK2. 
110 = SCC2 transmit clock is CLKS. 
111 = SCC2 transmit clock is CLK4. 


IPA PANL 


ipds 


Bits 24—-25—Reserved 
These bits are reserved and should be set to 0. 


R1CS—Clock Source for the USB 


000 = USB clock is BRG1. 
001 = USB clock is BRG@2. 
010 = USB clock is BRG3. 
011 = USB clock is BRG4. 
100 = USB clock is CLK1. 
101 = USB clock is CLK2. 
110 = USB clock is CLKS. 
111 = USB clock is CLK4. 


Bits 29-31—Reserved 
These bits are reserved and should be set to 0. 
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16.7.5.4 SERIAL INTERFACE COMMAND REGISTER. The 8-bit serial interface 
command register (SICMR) allows you to dynamically program the serial interface RAM. 
The contents of this register are only valid in the RAM division mode. For more information 
about dynamic programming, refer to Section 16.7.4.4 Serial Interface RAM pyhamic 
Changes. 


SICMR 





(IMMR & OxFFFFOO00) + 0xAE7 


CSRRA—Change Shadow RAM for TDMA Receiver 


When set, this bit causes the serial interface receiver to replace the current route with the 
shadow RAM. You set this bit and the serial interface clears it. 


0 = The receiver shadow RAM is not valid. You can write into the shadow RAM to 
program a new routing. 

1 = The receiver shadow RAM is valid. The serial interface exchanges between the 
RAMs and take the new receive routing from the receiver shadow RAM. This bit is 
cleared as soon as the switch has completed. 


CSRTA—Change Shadow RAM for TDMA Transmitter 


When set, this bit causes the serial interface transmitter to replace the current route with the 
shadow RAM. You set this bit and the serial interface clears it. 


0 = The transmitter shadow RAM is not valid. You can write into the shadow RAM to 
program a new routing. 

1 = The transmitter shadow RAM is valid. The serial interface exchanges between the 
RAMs and take the new transmitter routing from the receiver shadow RAM. This 
bit is cleared as soon as the switch has completed. 


Bits 2—7—Reserved 
These bits are reserved and should be set to 0. 
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16.7.5.5 SERIAL INTERFACE STATUS REGISTER. The 8-bit serial interface status 
register (SISTR) lets you know which part of the serial interface RAM is the current-route 
RAM. The value of this register is only valid when the corresponding bit in the SICMR is 
cleared. 


SISTR 


CRORA CROTA RESERVED 


(IMMR & OxFFFF0000) + OxAE6 





CRORA—Current Route of TDMA Receiver 


O= The current-route receiver RAM is in address 0-63 when the serial interface 
supports the TDM (RDM field in the SIGMR = 01). 

1 = The current-route receiver RAM is in address 64-127 when the serial interface. 
supports the TDM (RDM = 01). | 


CROTA—Current Route of TDMA Transmitter 


0 = Thecurrent-route transmitter RAM is in address 128—191 when the serial interface 
supports the TDM (RDM field in the SIGMR = 01). 

1 = The current-route transmitter RAM is in address 192—255 when the serial interface 
supports the TDM (RDM = 01). | 


Bits 2—7—Reserved 
These bits are reserved and should be set to 0. 


16.7.5.6 SERIAL INTERFACE RAM POINTER REGISTER. The 32-bit, read-only serial 
interface RAM pointer (SIRP) register lets you know which RAM entry is currently being 
serviced. It gives you a real-time status location of the serial interface that is currently inside 
the TDM frame. Although not everyone needs to access the SIFRP register, it does provide 
information that might be helpful for debugging and for synchronizing system activity with 
TDM activity. Usually, reading the SISTR is sufficient for most applications. 


You can determine which RAM entry in the serial interface RAM is currently in progress, but 
you cannot determine the status within that entry. If the RAM entry is programmed to select 
four contiguous time-slots from the TDM and the SIRP register indicates the entry is 
currently active, you will not know which of the four time-slots is currently in progress. The 
SIRP register does, however, change its status as soon as the next serial interface RAM 
entry begins processing. 


iz 4 Note: You can externally connect one of the eight strobes to an interrupt pin to 
generate an interrupt on a particular serial interface RAM entry. 
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The value of this register changes on serial clock transitions. Before acting on the 
information found in this register, you should perform two reads and verify that they returned 
the same value. The pointers provided by this register indicate the serial interface RAM entry 
word offset that is currently in progress. 


SIRP 


= 


AAS 
ASEN 
INR 


a a 


RESERVED RAPTR2 RESERVED 





(IMMR & OxFFFFO000) + OxAF2 





Bits 0-1 and 8—9—Reserved 
These bits are reserved and should be set to 0. 


VT1, VT2, VR1, and VR2—Time-Slot Valid Bits for Serial Interface RAM Entries 


The VTx or VRx bit in each entry shows that the entry is valid, which is helpful when the 
corresponding pointer entry value is zero. Additionally, the VTx or VRx bit saves you from 
having to read both the SIRP and the SISTR registers to obtain the information you need. 
The pointer values are based on the value of the RDM field in the SIGMR. 


Bits 16-17 and 24-25—Reserved 
_ These bits. are reserved and should be set to 0. 


TAPTR2, TAPTR1, RAPTR2, and RAPTR1—Serial Interface RAM Time-Slot Pointers 


In all cases, the value of the TAPTRx or RAPTRx fields increment by one for each entry that 
the serial interface processes. Since each TAPTRx and RAPTRx is 5 bits each, the values 
in each field can range from 0 to 31, corresponding to 32 different serial interface RAM 
entries. The full pointer range may not necessarily be used. For instance, if the last bit is set 
in the fifth serial interface RAM entry, then the pointer only reflects values from 0 to 4, but 
once the fifth entry is processed by the serial interface, the pointer is reset to 0. 
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16.7.5.6.1 SIRP Indication When RDM = 00. 64 entries cannot be signified with a single 
5-bit pointer, two 5-bit pointers are used instead—one for the first 32 entries and one for the 
second 32 entries. If the corresponding VTx or VRx bit is set, then: 


e RAPTR1 and RAPTR2 contain the address of the currently active RX RAM entry. When 
the serial interface services entries 1-82, RAPTR1 is incremented and RAPTR2 is 
continuously cleared. When the serial interface services entries 33-64, RAPTR1 is 
continuously cleared and RAPTR2 is incremented. 


e TAPTR1 and TAPTR2 contain the address of the currently active TX RAM entry. When 
the serial interface services entries 1-32, TAPTR1 is incremented and TAPTR2 is 
continuously cleared. When the serial interface services entries 33-64, TAPTR1 is 
continuously cleared and TAPTR2 is incremented. 


16.7.5.6.2 SIRP Indication When RDM = 01. For the receiver, either RAPTR1 or RAPTR2 
is used, depending on the portion of the serial interface RX RAM that is currently active. For 
the transmitter, either TAPTR1 or TAPTR2 is used, depending on the portion of the serial 
interface TX RAM that is currently active. If the corresponding VTx or VRx bit is set, then: 


e RAPTRI1 contains the address of the currently active RX RAM eniry. The serial 
interface RAM receive address block that is used is 0-63 and CRORA = 0 in the SISTR. 


° RAPTR2 contains the address of the currently active RX RAM entry. The serial 
interface RAM receive address block that is used is 64-127 and CRORA = 1 in the 
SISTR. 


e TAPTR1 contains the address of the currently active TX RAM entry. The serial interface 
RAM transmit address block that is used is 128-191 and CROTA = 0 in the SISTR. 


e TAPTR2 contains the address of the currently active TX RAM entry. The serial interface 
RAM transmit address block that is used is 192-255 and CROTA = 1 in the SISTR. 


16.7.6 IDL Interface Operation 


The full-duplex ISDN interchip digital link (IDL) interface is used to connect a physical layer 
device to the MPC823. The basic and primary rate of the IDL bus is supported by the 
MPC823. In the basic rate of IDL, data on three channels (B1, B2, and D) is transferred in a 
20-bit frame, providing 160kbps full-duplex bandwidth. The MPC823 is an IDL slave device 
that is clocked by the IDL bus master (physical layer device) and has separate receive and 
transmit sections. The MPC823 supports one IDL bus as illustrated in Figure 16-56. 
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Figure 16-56. IDL Bus Application Example 


16.7.6.1 IDL INTERFACE IMPLEMENTATION. The MPC823 can identify and support 
each IDL channel or it can output strobe lines for interfacing with devices that do not support 
the IDL bus. The IDL signals for each transmit and receive channel are as follows: 


LiRCLKA—IDL clock pin. Input to the MPC823. 
L1RSYNCA—IDL sync pin. Input to the MPC823. This signal indicates that the clock 
periods following the pulse designate the IDL frame. 


L1RXDA—IDL receive data pin. Input to the MPC823. Valid only for the bits that are 
supported by the IDL and ignored for other signals that may be present. 


LiTXDA—IDL transmit data pin. Output from the MPC823. Valid only for the bits that 
are supported by the IDL. Otherwise, it is three-stated. 

L1RQA—IDL request permission to transmit on the D channel. ome from the 
MPC823 on the L1RQA pin. 


Li1GRA—IDL grant permission to transmit on the D channel. lapui to the MPC823 on 
the L1TSYNCA pin. 


The basic rate IDL bus has three channels: 


B1 is a 64kbps bearer channel 
B2 is a 64kbps bearer channel 
D is a 16kbps signaling channel 


There are two definitions of the IDL bus frame structure—8 and 10 bits. The only difference 


~ between them is the channel order within the frame. 
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Figure 16-57. IDL Terminal Adaptor 
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10-BIT IDL 


LICLKA 
(CLOCK IS NOT TO SCALE) 


LiISYNCA | | 





8-BIT IDL 
LICLKA 
(CLOCK IS NOT TO SCALE) 
LISYNCA | | 


™ a 


NOTE: LiRQA AND L1GRA ARE NOT SHOWN. 


Figure 16-58. IDL Bus Signals 


Note: Previous versions of Motorola IDL-defined bit functions, called auxiliary (A) and 
maintenance (M), were eliminated from the IDL definition when it was concluded 
that the IDL control channel would be out-of-band. They were defined as a 
subset of the Motorola SPI format called serial control port (SCP). If you prefer 
to implement the A and M bit functions as originally defined, you can program the 
time-slot assigner to access these bits and route them transparently to a serial 
communication controller or serial management controller. To perform the 
out-of-band signaling required, use the MPC823 serial peripheral interface. 
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The MPC823 supports all channels of the IDL bus in the basic rate. Each bit in the IDL frame 
can be routed to every serial communication controller and serial management controller or 
they can assert a strobe output that supports an external device. 7 


The MPC823 supports the request-grant method for contention detection on the D channel 
of the IDL basic rate and when the MPC823 has data to transmit on the D channel, it asserts 
the L1RQA pin. The physical layer device monitors the physical layer bus for activity on the 
D channel and indicates that the channel is free by asserting the L1GRA pin. The MPC823 
samples the L1GRA pin when the IDL sync signal (L1RSYNCA) is asserted. If L1GRA is 
high (active), the MPC823 transmits the first zero of the opening flag in the first bit of the D 
channel. If a collision is detected on the D channel, the physical layer device negates 


L1GRA. The MPC823 then stops its transmission and retransmits the frame when L1GRA 


is reasserted. This procedure is handled automatically for the first two buffers of a frame. 


For the primary rate IDL, the MPC823 supports up to four 8-bit channels in the frame, 
determined by the serial interface RAM programming. Additionally, the MPC823 can be 
used to assert strobes to support additional external IDL channels. The IDL interface 
supports the CCITT 1.460 recommendation for data rate adaptation since it separately 
accesses each bit of the IDL bus. The current-route RAM specifies the bits that are 
supported by the IDL interface and the serial controller. The receiver only receives the bits 
that are enabled by the receiver route RAM. Otherwise, the transmitter only transmits the 
bits that are enabled by the transmitter route RAM and three-states the L1TXDA pin. 


16.7.6.2 PROGRAMMING THE IDL INTERFACE. You can program the channels used for 
the IDL bus interface to the appropriate configuration. First, using the GMA bit, program the 
SIMODE register to the IDL grant mode for that channel. If the receive and transmit section 
are used for interfacing to the same IDL bus, using the CRTA bits you can internally connect 
the receive clock and sync signals to the serial interface RAM transmit section. However, 
the RAM section used for the IDL channels must be programmed to the preferred routing. 
For more information, see Section 16.7.5 Serial Interface Programming Model. 


You should now define the IDL frame structure to be a 1-bit delay from frame sync to data, 
to falling edge sample sync, and the clock edge to transmit on the rising edge of the clock. 
Program the L1TXDA pin to be three-stated when inactive by using the parallel I/O 
open-drain register. To support the D channel, you must program the appropriate GMA bit 
in the SIMODE register and program the RAM entry to route data to that serial controller. 
The two definitions of IDL—8 and 10 bits—are only supported by modifying the serial 
interface RAM programming. In both cases, the L1GRA pin is sampled with the LI1TSYNCA 
signal and transferred to the D channel serial communication controller as a grant indication. 
The same procedure is used to support an IDL bus in the second channel. 
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16.7.6.2.1 IDL Interface Programming Example. Using the example in 
Section 16.7.6.1 IDL Interface Implementation as a base model, the initialization 
sequence is as follows: 


ale 


ON Oo 


9. 





Assuming SMC1 is connected to the B1 channel, SMC2 is connected to the B2 
channel, and SCC2 is connected to the D channel, program the serial interface RAM. 
Write all entries that are not used with 0x0001, set the LST bit, and disable the routing 
function. , | 













ENTRY RAM WORD 


ENTRY. 
A 
[ow [ooo once [0 [0 | a8 No Spon 
[2 [enw [si [ ooo [+ [0 | ee sue 6a) 
an ae a 





0000 0000 1 Bit SCC2 





a 


Note: Since IDL requires the same routing for both receive and transmit, an exact 
-. duplicate of the above entries should be written to both the receive and transmit 
sections of the serial interface RAM beginning at serial interface RAM addresses 

0 and 128, respectively. | 


. SIMODE = 0x80008145. Only TDMa is used. The two SMCs are connected to the 


time-slot assigner. a 3 


. SICR = 0x0000c000. SCC2 is connected to the time-slot assigner. SCC2 supports the 


grant mechanism since it is on the D channel. | 
PAODR bit 9 = 1. Configure L1TXDa to be an open-drain output. 


. PAPAR bits 9, 8, and 7 = 1. Configure L1TXDa, L1RXDa, and Li1RCLKa. 
. PADIR bits 9 and 8 = 1. PADIR bit 7 = 0. Configure L1TXDa, L1RXDa, and L1RCLKa. 
. PCPAR bits 12, 5, and 11 = 1. Configure L1RQa, L1TSYNCa, and L1RSYNCa. 


PCDIR bit 12 = 0. L1RQa is an input. L1TSYNCa performs the L1GRa function and is 
therefore an output, but it does not need to be configured with PCDIR bit 5 = 0. — 
LiRSYNCa is an input, but it does not need to be configured with a PCDIR bit. 


SIGMR = 0x04. Enable TDMa (one static TDM). 


10. SICMR is not used. 
11.SISTR and SIRP do not need to be read, but can be used for debugging information 


once the channels are enabled. 


12. Enable SCC2 to HDLC operation (to handle the LAPD protocol of the D channel). Set 


SCC2 and SMC1 to transparent operation. 
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16.7.7 GCI Interface Operation 


The normal mode of the general circuit interface (GCI) and SCIT are fully supported by the 
MPC823. It also supports the D channel access control in S/T interface terminals by using 
the command/indication (C/I) channel for that function. 


The GCI bus consists of four lines—two data lines, a clock, and a frame synchronization line. 
Usually, an 8kHz frame structure defines the various channels within the 256kbps data rate. 
The MPC823 supports an independent GCI bus and has independent receive and transmit 
sections. The interface can also be used in a multiplexed frame structure on which up to 
eight physical layer devices multiplex their GCI channels. In this mode, the data rate would 
be 2,048kbps. In the GCI bus, the clock rate is twice the data rate. The serial interface 
divides the input clock by two to produce the data clock. The MPC823 also has data strobe 
lines that are used as an interface for devices that do not support the GCI bus. The GCI 
signals for each transmit and receive channel are as follows: 


e LIRSYNCA—Used as a GCI sync signal. Input to the MPC823. This signal indicates 
that the clock periods following the pulse designate the GCI frame. 


e Li1RCLKA—Used as a GCI clock. Input to the MPC823. The L1RCLKA signal is twice 
the data clock. 
e L1RXDA—Used as a GCI receive data. Input to the MPC823. 


e L1TXDA—Used as a GCI transmit data. Open-drain output. Valid only for the bits that 
_ are supported by the IDL. Otherwise, it is three-stated. 


LiCLK 

(2X THE DATA RATE) | (CLOCK IS NOT TO SCALE) 
LiSYNC | 
LIRXD MONITOR Dijo2| cl {TIE 
LITXD MONTOR _Jorfoa] ci) _[T]e 


Figure 16-59. GCI Bus Signals 


In addition to the 144kbps ISDN 2B+D channels, the GCI provides five channels for 
maintenance and control functions: 


e B1 is a 64kbps bearer channel 

e B2 is a 64kbps bearer channel 

e Mis a 64kbps monitor (M) channel 

e Dis a 16kbps signaling channel 

e C/lis a 48kbps C/I channel (includes Tand E bits) 
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The M channel is used to transfer data between layer 1 devices and the control unit (the 
core) and the C/I channel is used to control activation/deactivation procedures or to switch 
test loops by the control unit. The M and C/I channels of the GCI bus should be routed to 
SMC1 or SMC2, which have modes to support the channel protocols. The MPC823 can 
support any channel of the GCI bus in the primary rate by modifying the serial interface RAM 
programming. 


The GCI supports the CCITT 1.460 recommendation as a method for data rate adaptation 
since it can access each bit of the GCI separately. The current-route RAM specifies which 
the bits that are supported by the interface and serial controller. The receiver only receives 
the bits that are enabled by the serial interface RAM and the transmitter only transmits the 
bits that are enabled by the serial interface RAM and does not drive L1TXDA. Otherwise, 
L1TXDA is an open-drain output and should be externally pulled high. 


The MPC823 supports contention detection on the D channel of the SCIT bus. When the 
MPC823 has data to transmit on the D channel, it checks a SCIT bus bit that is marked with 
a special route code (usually, bit 4 of C/I channel 2). The physical layer device monitors the 
physical layer bus for activity on the D channel and indicates on this bit that the channel is 
free. If a collision is detected on the D channel, the physical layer device sets bit 4 of C/I 
channel 2 to logic high. The MPC823 then aborts its transmission and retransmits the frame 
when this bit is set again. This procedure is automatically handled for the first two buffers of 
a frame. 


16.7.7.1 GCI ACTIVATION/DEACTIVATION PROCEDURE. In the deactivated state, the 
clock pulse is disabled and the data line is at a logic one. The layer 1 device activates the 
MPC823 by enabling the clock pulses and sending an indication to C/I channel 0. Using a 
maskable interrupt, the MPC823 lets the core know that a valid indication has been received 
in the SMC receive buffer descriptor. 


When the core activates the line, the data output of L1TXDA is programmed to zero by 
setting the STZA bit in the SIMODE register. Code 0 (command timing TIM) is transmitted 
on C/I channel 0 to the layer 1 device until the STZA bit is reset. The physical layer device 
resumes the clock pulses and gives an indication in C/I channel 0. The core should reset the 
STZA bit to enable data output. 


16.7.7.2 PROGRAMMING THE GCI INTERFACE. There are two modes of the GCI 
interface—normal and SCIT. | 


16.7.7.2.1 Normal Mode. You can program and configure the channels used for the GC! 
bus interface. First, program the SIMODE register to the GCI/SCIT mode for that channel. 
This mode defines the sync pulse to GCI sync for framing and data clock as one-half the 
input clock rate. You can program more than one channel to interface to the GCI bus. Also, 
if the receive and transmit section are used for interfacing the same GCI bus, using the 
CRTA bit you should internally connect the receive clock and sync signals to the serial 
interface RAM transmit section. Then you should define the GCI frame routing and strobe 
select using the serial interface RAM. 
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When the receive and transmit sections use the same clock and sync signals, these sections 
should be programmed to the same configuration. Also, the L1TXDA pin in the I/O register 
should be programmed to be an open-drain output. To support the monitor and C/I channels 
in GCI, those channels should be routed to one of the serial management controllers. To 
support the D channel when there is no possibility of collision, you should clear the GRA bit 
corresponding to the serial communication controller that supports the D channel in the 
SIMODE register. 


16.7.7.2.2 SCIT Mode. To interface with the GCI/SCIT bus, the SIMODE register must be 
programmed to GCI/SCIT mode. The serial interface RAM is programmed to support a 
96-bit frame length and the frame sync is programmed to the GCI sync pulse. Generally, the 
SCIT bus supports the D channel access collision mechanism. For this purpose, you should 
program the receive and transmit sections to use the same clock and sync signals with the 
CRTA bit and program the GRA bit to transfer the D channel grant to the serial 
communication controller that supports this channel. The received bit should be marked by 
programming the channel select bits of the serial interface RAM to 111 for an internal 
assertion of a strobe on this bit. This bit is sampled by the serial interface and transferred to 
the D channel serial communication controller as the grant. The bit is generally bit 4 of the 
C/l in channel 2 of GCI, but any other bit can be selected using the serial interface RAM. 


16.7.7.3 GCI INTERFACE PROGRAMMING EXAMPLE. Assuming SCC2 is connected to 
the D channel, SMC2 to the B1 channel, and SMC1 to the C/I channels, the initialization 
sequence is as follows: 


1. Program the serial interface RAM. Write all entries that are not used with 0x0001, set 
the LST bit, and disable the routing function. 


ENTRY — RAM WORD 


3 8 Bits SMC1 (M) 


D Grant Bit 





oy 4 Note: Since GCI requires the same routing for both receive and transmit, an exact 

) duplicate of the above entries should be written to both the receive and transmit 
sections of the serial interface RAM beginning at addresses 0 and 128, 
respectively. 
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2. SIMODE = 0x0000c000. SCC2 is connected to the time-slot assigner. SCC2 supports 
the grant mechanism since it is on the D channel. 


“oO Note: If SCIT mode is not used, delete the last three entries of the serial interface RAM 
and set the LST bit in the new last entry. 


3. SICR = 0x000040C0. SCC2 is connected to the time-slot assigner. 

4. PAODR bit 9 = 1. Configure L1TXDa to be an open-drain output. 

5. PAPAR bits 9, 8, and 7= 1. Configure L1TXDa, L1RXDa, and L1RCLKa. 

6. PADIR bits 9 and 8 = 1.PADIR bit 7 = 0. Configure L1TXDa, L1RXDa, and L1RCLKa. 
7. PCPAR bit 4 = 1. Configure L1RSYNCa. 

8. SIGMR = 0x04.Enable TDMa (one static TDM). 

9. SICMR is not used. 

{ 


0.SISTR and SIRP do not need to be read, but can be used for debugging information 
once the channels are enabled. 


11. Enable SCC2 for HDLC operation (to handle the LAPD protocol of the D channel). Set 
-SMC1 for SCIT operation. Set SMC2 for transparent operation. 


16.7.8 Nonmultiplexed Serial Interface Configuration 


The serial interface supports a nonmultiplexed serial interface (NMSI) mode for the serial 
communication controller and serial management controllers. The decision of whether to 
connect SCC2 to the NMSI is made in the SICR and the decision of whether to connect a 
serial management controller to the NMSI is made in the SIMODE register. The serial 
communication controller or serial management controllers can be connected to the NMSI, 
regardless of the other channels connected to a TDM channel. You should keep in mind, 
however, that NMSI pins can be multiplexed with other functions at the parallel I/O lines. 
Therefore, if a combination of the TDMA and NMSI channels is used, you should consult the 
MPC823 pinout in Section 2 External Signals to decide which serial communication 
controller or serial management controller to connect and where to connect them. 


The clocks that are provided to the universal serial bus, serial communication controller, and 
serial management controllers are derived from six sources—four internal baud rate 
generators and four external CLK pins. There are two main advantages to this 
bank-of-clocks approach. First, a universal serial bus, serial communication controller, or 
serial management controller is not forced to choose its clock from a predefined pin or baud 
rate generator, which adds flexibility to the pinout mapping strategy. Second, if a group of 
SMC receivers and transmitters need the same clock rate they can share the same pin, 
which leaves other pins available for other functions and minimizes the potential skew 
between multiple clock sources. 
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The four baud rate generators also make their clocks available to external logic, regardless 
of whether they are being used by a serial communication controller or serial management 
controller. The BRGOx pins are multiplexed with other functions, so all BRGOx pins may not 
always be available. For more information, see the pinout in Section 2 External Signals. 
The bank-of-clocks mapping has one restriction—the SMC transmitter must have the same 
clock source as the receiver when connected to the NMSI pins. 


Once the clock source is selected, the clock is given an internal name. For the serial | 
communication controller, the name is RCLK2 and TCLK2 and for the serial management 
controllers, the name is SMCLKx. These internal names are used only in NMSI mode to 
specify the clock that is sent to the serial communication controller or serial management 
controller. These names do not correspond to any pins on the MPC823. 


Note: The internal RCLK2 and TCLK2 can be used as inputs to the DPLL unit, which 
is inside the serial communication controller. Thus, the RCLK2 and TCLK2 
signals are not always required to reflect the actual bit rate on the line. 
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The pins available to the universal serial bus, serial communication controller, and serial 
management controllers in NMSI mode are illustrated in Figure 16-60. 





BRGO1 
BRGO2 
BRGO3 
AA RCLK2 | 
<— CLKi 
sila | BANK OF CLOCKS r<— cLk2 
TX : SELECTION LOGIC CLK3 
<— CLK4 


USB USBCLK | 
CLOCK 


SMCI SMCLK1 | 
| —_ USB AND SCC2 CONTROLLED INTHE SICR 


SNC2 oe SMCs CONTROLLED IN THE SIMODE REGISTER 


Figure 16-60. Bank of Clocks 
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Communication Processor Module 


USB in NMSI mode has its own set of modem control pins: 


e USBRXD 

e USBRXP 

e USBTXP 

e USBCLK — BRG1-—BRG4, CLK1—CLK4 
e USBRXN 

e USBOE 


SCC2 in NMSI mode has its own set of modem control pins: 


e TXD2 

° RXD2 

¢ TCLK2 — BRG1-BRG4, CLK1-CLK4 
¢ RCLK2 — BRG1-BRG4, CLK1—CLK4 
¢ RTS2 | 

© CTS2 

© CD2 


SMC1 in NMSI mode has its own set of modem control pins: 


e SMTXD1 

e SMRXD1 

e SMCLK1 — BRG1—BRG4, CLK1—CLK4 

¢ SMSYN1 (used only in the totally transparent protocol) 


SMC2 in NMSI mode has its own set of modem control pins: 


e SMTXD2 
e SMRXD2 
e SMCLK2 — BRG1-—BRG4, CLK1—CLK4 
e SMSYN2 (used only in the totally transparent protocol) 
A universal serial bus, serial communication controller, or serial management controller that 


requires fewer pins than those listed above can use that pin for another function or configure 
that pin as a parallel I/O pin. 


16-150 | _ MPC823 USER’S MANUAL MOTOROLA 


Communication Processor Module 


16.8 THE BAUD RATE GENERATORS 


The communication processor module contains four, independent, identical baud rate 
generators (BRGs) that can be used with the universal serial bus, serial communication 
controller, and serial management controllers. The clocks produced in the baud rate 
generator are sent to the bank-of-clocks selection logic, where they can be routed to the 
universal serial bus, serial communication controller, or serial management controllers. In 
addition, the output of the baud rate generator can be routed to a pin to be used externally. 
The following is a list of baud rate generators’ main features: 


e Four independent and identical baud rate generators. If you are using Mask Revision 
Base #F98S, there are only two baud rate generators. 


e On-the-fly changes are allowed. 


tty 


e Each baud rate generator can be routed to the universal serial bus, serial 
communication controller, or serial management controllers. \ 


RBlas 


e A 16x divider option allows low baud rates at high system frequencies 
e Each baud rate generator contains an autobaud support option. 
e Three of the baud rate generator outputs can be routed to the BRGOx pin. | 


The baud rate generator block diagram is illustrated in Figure 16-61. 


EXTC FIELD DIV 16 M | CD11-CD0 


CLKi PIN 

CLK2 PIN TO PIN 
Sau PRESCALER 42 BIT inter 

CLK PIN DIVIDE BY COUNTER 

CLK4 PIN 1OR 16 1-4,096 BANK OF 

BRGCLK — CLOCKS 


= 


TX SOURCE CONTROL 
BAUD RATE GENERATOR 





Figure 16-61. Baud Rate Generator Block Diagram 
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Communication Processor Module 


The clock input to the prescaler can be selected by the EXTC field in the BRGCx register to 
originate in one of five sources—BRGCLK, CLK1, CLK2, CLK3, or CLK4. 


The BRGCLK is generated in the MPC823 clock synthesizer specifically for the four baud 
rate generators, serial peripheral interface, and I?C internal baud rate generator. You can 
also configure the CLK1, CLK2, CLK3, or CLK4 pins to be the clock source. An external pin 
allows flexible baud rate frequency generation, regardless of the system frequency. 
Additionally, the CLK1, CLK2, CLK3, or CLK4 pins allow a single external frequency to 
become the input clock for multiple baud rate generators. The clock signals on the CLK1, 
CLK2, CLKS, or CLK4 pins are not synchronized internally prior to being used by the baud 
rate generator. 


Next, the baud rate generator provides a divide-by-16 option before the clock reaches the 
prescaler. This option is chosen by the DIV16 bit. The clock is then divided into the prescaler 
by a maximum of 4,096. This input clock divide ratio can be programmed on-the-fly. 
However, on-the-fly baud rate generator changes should not occur within a shorter time than 
the period of two baud rate generator input clocks. | 


“oO Note: Four baud rate generators are available for the SCC and SMCs. However, 
BRGO4 cannot be output externally. 


The output of the prescaler is sent internally to the bank of clocks and can also be output 
externally on the BRGOx pins of either the port A or port B parallel 1/0. One BRGOx pin is 
an output from the corresponding baud rate generator. If the baud rate generator divides the 
clock by an even value, the transitions of the BRGOx pin always occur on the falling edge 
of the input clock to the baud rate generator. If the baud rate generator is programmed to an 
odd value, the transitions alternate between the falling and rising edges of the input clock. 
Additionally, the output of the baud rate generator can be sent to the autobaud control block. 
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16.8.1 Autobaud Operation | 


Using the autobaud process, a UART determines the baud rate of its received character 
stream by examining the pattern received and the timing information of that pattern. The 
MPC823 baud rate generators have a built-in autobaud control function that automatically 
measures the length of a start bit and modifies the baud rate accordingly. If the ATB bit in 
the BRGCx register is set, the autobaud control block starts searching for a low level on the 
RXD2 signal, which it assumes is the beginning of a start bit and begins counting the start 
bit length. During this time, the BRG output clock toggles for 16 BRG clock cycles at the BRG 
input clock rate and then stops with the BRGOx output clock in the low state. 


After the RXD2 signal changes back to the high level, the autobaud control block rewrites 
the CD and DIV16 bits in the BRGCx register to the divide ratio it found. Due to a 
measurement error that occurs at high baud rates, this divide ratio written by the autobaud 
controller may not be the precise, baud rate you prefer (56,600 could be the resulting baud 
rate, rather than 57,600). Thus, an interrupt is provided for you in the SCCE—UART register 
to signify that the BRGCx register was rewritten by the autobaud controller. When this 
interrupt is recognized, you should rewrite the BRGCx with the value you prefer. It is 
recommended that this be done as quickly as possible (even prior to the first character being 
fully received) to ensure that all characters are recognized correctly by the UART. 


Once a full character is received, you can check the software to verify that the received 
character matches a predefined value (such as “a” or “A”). The software should then check 
for other characters (such as “t” or “T”) and program the serial communication controller to 
the preferred parity mode. You can change the parity mode in the SCC2 UART mode 
register (PSMR-—SCC2 UART), which is in Section 16.9.3 Protocol-Specific Mode 
Register. 


Note: The serial communication controller associated with this baud rate generator 
must be programmed to UART mode and have the TDCR and RDCR fields in 
the GSMR_L set to the 16x option for the autobaud function to operate correctly. 
Input frequencies such as 1.32MHz, 3.68MHz, 7.36 MHz, and 14.72MHz should 
be used. For autobaud to operate successfully, the serial communication 
controller must be connected to the baud rate generator. For instance, SCC2 
must be clocked by BRG2 to successfully perform the autobaud function. Also, 
for the serial communication controller to correctly detect an autobaud lock and 
generate an interrupt, it must receive three full RX clocks from the baud rate 
generator before the autobaud process begins. To do this, set the ATB bit to 0 
in the BRGCx register and enable the BRGx receive clock to the highest 
frequency. Immediately prior to the start of the autobaud process (after device 
initialization), set the ATB bit to 1. 
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Communication Processor Module 


16.8.2 Baud Rate Generator Configuration Registers 


The 32-bit, memory-mapped baud rate generator configuration registers (BRGC1—4) are 
are used to configure the baud rate generators. At reset, the baud rate generators are 
disabled and the BRGOx output clock is high. These registers can be written at any time and 
you do not need to disable any internal or external devices connected to the BRGOx output 
clock. Changes to the baud rate generators occur at the end of the next BRG clock cycle (no 
spikes occur on the BRGOx output clock). 


BRGC1—BRGC4 


(IMMR & OxFFFFO000) + 0x9F2 (BRGC1), 0x9F6 (BRGC2), 0x9FA (BRGC3), Ox9FE (BRGC4) 





Bits O—13—Reserved 
These bits are reserved and should be set to 0. 


RST—Reset Baud Rate Generator 


This bit performs a software reset of the baud rate generator identical to that of an external 
reset. A reset disables the baud rate generator and sets the BRGOx output clock. This can 
only be seen externally if the BRGOx function is enabled to reach the corresponding port A 
or B parallel I/O pin. 


O= Enable the baud rate generator. 
Reset the baud rate generator (software reset). 


EN—Enabie Baud Rate Generator Count 


This bit is used to dynamically stop the baud rate generator from counting, which may be 
useful for low-power modes. 


0 = Stop all clocks to the baud rate generator. 
1 = Enable clocks to the baud rate generator. 
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EXTC—External Clock Source 


This field selects the baud rate generator input clock from the internal BRGCLK or one of 
three external pins. 


00 = The baud rate generator input clock comes from the BRGCLK (internal clock 
generated by the clock synthesizer in the system interface unit). 

01 = The baud rate generator input clock comes from the CLK2 pin. 

10 = The baud rate generator input clock comes from the CLK4 pin. 

11 = Reserved. 


ATB—Autobaud 


When set, this bit selects autobaud operation of the baud rate generator on the 
corresponding RXD2 pin. 


O = Normal operation of the baud rate generator. | 
1 = When RXD2 goes low, the baud rate generator determines the length of the start 
bit and synchronizes the baud rate generator to the actual baud rate. 


Note: The ATB bit must remain clear (0) until the serial communication controller 
receives the three RX clocks. Then you must set this bit to one to obtain the 
correct baud rate. Once the baud rate is obtained and locked, it is indicated by 
setting the AB bit in the UART SCCE register in Section 16.9.8.1 SCC2 Event 
Register. This bit may only be set for BRG2. 





CD—Clock Divider 


This field and the prescaler determines the baud rate generator output clock rate. They are 
used to preset a 12-bit counter that is decremented at the prescaler output rate, but the 
counter is inaccessible to you. When the counter reaches zero, it is reloaded from the clock 
divider bits. Thus, a value of OxFFF in CDO—CD11 produces the minimum clock rate (divide 
by 4,096), and a value of 0Ox0000 produces the maximum clock rate (divide by 1). Even when 
dividing by an odd number, the counter ensures a 50% duty-cycle by asserting the terminal 
count once on clock low and next on clock high. The terminal count signals counter 
expiration and toggles the clock. 


DIV16—BRG Clock Prescaler Divide by 16 


0 = Divide by 1 for the clock divider input. 
1 = Divide-by-16 prescaler enabled for the clock divider output. 
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Communication Processor Module 


16.8.3 UART Baud Rate Examples 


For synchronous communication using the internal baud rate generator, the BRGOx output 


clock must never be faster than the system frequency divided by 2. So, with a 25MHz 
system frequency, the maximum BRGOx output clock rate is 12.5MHz. You should program 
the UART to 16x oversampling when using the serial communication controller as a UART. 
On the MPC823, 8x and 32x options are also available. Assuming 16x oversampling is 
chosen in the UART, a data rate of 25MHz + 16 = 1.5625Mb/sec is the maximum possible 
UART speed. Putting this together, the following formula should be used to calculate the bit 
rate based on a particular baud rate generator configuration for a UART: 


async baud rate = (BRGCLK, CLK1, CLK2, CLK3 or CLK4) ~ (clock divider + 1) + 
(1 or 16 depending on the DIV16 bit) = (8, 16, or 32 accoraing 


to the RDCR and TDCR fields in the GSMR_L register). 


The following table lists typical bit rates of asynchronous communication. The internal clock 
rate is assumed to be 16x the baud rate. | 


Table 16-23. Typical Baud Rates of Asynchronous Communication 


MPC823 SYSTEM FREQUENCY (MHz) 










FREQUENCY FREQUENCY FREQUENCY 
soo [0 [awe [emo [0 [asa] soo | 0 [asso | coo 
ia00 | 0 [iow [amr [0 [ror | seco | 0 | vr 
aoo | a | sao | ame [0 | om = 
[soo [of sae | asisa [0 
a 
[seo [0 | xe | svero [0 
[orem [0 | a | score [0 
Frisaw | o [| voees [0 





NOTE: All values are decimal. 
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For synchronous communication, the internal clock is identical to the baud rate output. To 
get the preferred rate, you can select the appropriate system clock according to the following 
equation: 


sync baud rate= (BRGCLK, CLK1, CLK2, CLK3 or CLK4) + (clock divider + 1) ~ 
(1 or 16 according to the DIV16 bit) 


To get a rate of 64kbps, the system clock can be 24.96MHz, DIV16 = 0, and the clock 
divider = 389. 


16.9 THE SERIAL COMMUNICATION CONTROLLER 


The MPC823 has a serial communication controller (SCC2) that can be configured 
independently to implement different protocols. It can be used to implement bridging 
functions, routers, gateways, and interface with a wide variety of standard WANs, LANs, and 
proprietary networks. The serial communication controller has many physical interface 
options such as interfacing to TDM buses, ISDN buses, and standard modem interfaces. 


The serial communication controller does not include the physical interface, but it is the logic 
that formats and manipulates the data obtained from the physical interface. That is why the 
serial interface is described in a different section. The protocol you choose is independent 
of your physical interface preference. The serial communication controller is described in 
terms of the protocol that you choose to run. When a serial communication controller is 
programmed to implement a certain protocol or mode, a certain level of functionality is 
associated with that protocol. For most protocols, this corresponds to the different parts of 
the link layer. Many functions of the serial communication controller are common to all of the 
following protocols: 


e UART controller 

e HDLC controller 

e HDLC bus controller 

° AppleTalk/LocalTalk controller 
e Asynchronous HDLC controller 
e IrDA controller 

e Transparent controller 

e Ethernet controller 


Although the selected protocol usually applies to both the SCC2 transmitter and receiver, 
the serial communication controller can run half of the serial communication controller with 
transparent operation while the other half runs the standard protocol. 
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Communication Processor Module 


Each of the internal clocks for the serial communication controller can be programmed with 
either an external or internal source. The internal clocks originate from one of four baud rate 
generators or one of four external clock pins. These clocks can be as fast as a 1:2 ratio of a 
12.5MHz system clock. However, the serial communication controller's ability to support a 
sustained bitstream depends on the protocol as well as other factors. Associated with the 
serial communication controller is a digital phase-locked loop (DPLL) for external clock 
recovery, which includes NRZ, NRZI, FMO, FM1, Manchester, and Differential Manchester. 
The DPLL can be configured to NRZ operation to pass the clocks and data to or from the 
serial communication controller without modifying it. 


The RISC microcontroller is responsible for selecting and controlling the various ports and 
controllers of ine communication processor module. For the serial communication controller 
command set, refer to Table 16-2. 


The serial communication controller can be connected to its own set of pins on the MPC823. 
This configuration is called the nonmultiplexed serial interface (NMSI) and is described in 
Section 16.7 The Serial Interface with Time-Slot Assigner. In this configuration, the 
serial communication controller can support the standard modem interface signals—RTS, 
CTS, and CD—through the port B or C pins and the CPM interrupt controller. Additional 
handshake signals can be supported with additional parallel I/O lines. The serial 
communication controller block diagram is illustrated in Figure 16-62. 
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Figure 16-62. Serial Communication Controller Block Diagram 
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16.9.1 Features 


The following is a list of the serial communication controller's main features: 


e Implements the HDLC, HDLC bus, asynchronous HDLC, synchronous start/stop, 
asynchronous start/stop, AppleTalk, Transparent, and Ethernet protocols 


e Supports full 1OMbps Ethernet/IEEE 802.3 
¢ Asingle HDLC or transparent channel can be supported at 8Mbps (full duplex) 
e Maximum clocking rates of 12.5MHz at 25MHz 


e DPLL circuitry for clock recovery with NRZ, NRZI, FMO, FM1, Manchester, and ( 
Differential Manchester (also known as Differential Bi-phase-L) 7 


e Clocks can be derived from a baud rate generator, an external pin, or DPLL; data clock 
can be as high as 3.125MHz with a 25MHz clock 


¢ Supports automatic control of the RTS, CTS, and CD modem signals 


e Multibuffer data structure for receive and transmit (up to 512 buffer descriptors can be 
partitioned in any way) | 


e Deep FIFOs 
e Transmit-on-demand feature decreases time-to-frame transmission 


¢ Low FIFO latency option for transmit and receive in character-oriented and totally. 
transparent protocols 


e Frame preamble options 
e Full-duplex operation 


e Fully transparent option for receiver/transmitter while another protocol executes on the 
transmitter/receiver 


e Echo and local loopback modes for testing 


Note: The serial communication controller is the same on both the MPC821 and 
MPC823, except that the MPC823’s SCC2 supports a wider range of IrDA 
signaling rates. The register control bits have been removed so the SIR and IRP 
bits of the GSMR_H and GSMR_L are reserved on the MPC823. However, the 
MPC823 does not support the BISYNC protocol or the external 
content-addressable memory (CAM) for the Ethernet/IEEE 802.3 protocol. 
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Communication Processor Module 


16.9.2 The General SCC2 Mode Registers 


The serial communication controller contains two high and low read/write general SCC2 
mode registers (GSMR_H and GSMR_L) that define all the options common to the serial 
communication controller, regardless of the protocol. These registers are cleared at reset 
and since they are 64 bits in length, they are accessed as GSMR_L and GSMR_H. GSMR_L 
contains the first (low-order) 32 bits of the GSMR and GSMR_H contains the last 32 bits. 


GSMR_H 


RESERVED 


(IMMR & OxFFFO000) + 0xA26 





Bits O-14—-Reserved 
These bits are reserved and should be set to 0. 


GDE—Glitch Detect Enable 


This bit determines whether the serial communication controller will search for glitches on 

the external receive and transmit serial clock lines provided. If this feature is enabled, the 

presence of a glitch is reported in the SCC2 event register. Whether or not the GDE bit is 

set, the serial communication controller always attempts to clean up the clocks that it uses 
internally, via a schmitt trigger on the input lines. 


O = No glitch detection is performed. This option should be chosen if the external serial 
clock exceeds the limits of the glitch detection logic (6.25MHz assuming a 25MHz 
system clock). This option should also be chosen if the SCC2 clock is provided — 
from one of the internal baud rate generators. Lastly, this option should be chosen 
if external clocks are used and it is more important to minimize power consumption 
than to watch for glitches. 

1 = Glitch detection is performed with a maskable interrupt generated in the SCC2 
event register. 
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TCRC—Transparent CRC (Totally Transparent Mode Only) 


This field selects the type of frame checking that is provided on the transparent channels of 
the serial communication controller (either the seceiver, transmitter, or both, as defined by 
the TTX and TRX bits). Although this configuration selects a frame check type, the actual 
decision to send the frame check is made in the TX buffer descriptor. Thus, it is not required 
to send a frame check in transparent mode. If a frame check is not used, you can simply 
ignore the frame check errors that are generated on the receiver. 


00 = 16-bit CCITT CRC (HDLC). (X16 + X12 4+ X54 1). 

O1 = CRC16. (X16 + X15 + X2 + 1). 

10 = 32-bit CCITT CRC (Ethernet, HDLC, and High-Speed IrDA). 
(X32 + X26 + X23 + X22 + X16 + X12 + X11 + X10 + XB + X7 + X5+ X44 X24 
X1 +1). Also called CRC32. 

11 = Reserved. 


REVD—Reverse Data (Transparent Mode Only) 


O = Normal operation. 

1 = When set, this bit causes the totally transparent channels on this serial 
communication controller (either the receiver, transmitter, or both) to reverse the 
bit order, transmitting the MSB of each octet first. 


TRX—Transparent Receiver 


The serial communication controller offers totally transparent operation. However, to 
increase flexibility, totally transparent operation is not configured with the MODE field of the 
GSMR_L, but with the TTX and TRX bits. This gives you the opportunity to implement 
unique applications, such as configuring an SCC2 transmitter to a UART and configuring the 
receiver to a totally transparent operation. To do this, set MODE = UART, TTX = 0, 

and TRX = 1. : 


O = Normal operation. 
1 = The receiver operates in totally transparent mode, regardless of the protocol 
selected for the transmitter in the MODE field of the GSMR_L. 


Note: Full-duplex transparent operation for a serial communication controller is 
obtained by setting both TTX and TRX. A serial communication controller cannot 
operate with Ethernet on its transmitter or while transparent operation is on its 
receiver. In other words, if the MODE field is set for Ethernet, then TTX must 
equal TRX or erratic operation will occur. 
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Communication Processor Module 


TTX—Transparent Transmitter 


The serial communication controller offers totally transparent operation. However, to 
increase flexibility, totally transparent operation is not configured with the MODE field, but 
with the TTX and TRX bits. This gives you the opportunity to implement unique applications, 
such as configuring an SCC2 receiver to an HDLC and configuring a transmitter to a totally 
transparent operation. To do this, set MODE = HDLC, TTX = 1, and TRX = 0. 


0 = Normal operation. 
1 = The transmitter operates in totally transparent mode, regardless of the protocol 
selected for the receiver in the MODE field of the GSMRP_L. 


iw A Note: Full-duplex transparent operation for a serial communication controller is 

| obtained by setting both TTX and TRX. The serial communication controller 
cannot operate with Ethernet on its receiver or while transparent operation is on 
its transmitter. In other words, if the MODE field is set to Ethernet, then TTX must 
equal TRX or erratic operation will occur. 


CDP—Carrier-Detect Pulse 
This bit must be set if the serial communication controller is used in the time-slot assigner. 


Q= Normal operation (envelope mode). The CD ) signal should envelope the frame. 
Negating CD while receiving data causes a CD lost error. 

1 = Pulse mode. Once the CD D signal is asserted, synchronization has been achieved 
and further transitions of CD have no effect on reception. 


CTSP—CTS Pulse 


0 = Normal operation (envelope mode). The CTS signal should envelope the frame. 
Negating CTS while transmitting data causes a CTS lost error. 
1 = Pulse mode. Once the CTS signal is asserted, synchronization has been achieved 
and further transitions of CTS have no effect on transmission. 


CDS—Carrier-Detect Sampling 


~0= The CD signal is assumed to be asynchronous with the data. It is internally 
synchronized by the serial communication controller and then data is received. 

~1= The CD signal is assumed to be synchronous with the data, which speeds up 
operation. In this mode, CD must transition while the receive clock is in the low 
state. As soon as CD is low, data is received. This mode is especially useful when 
connecting an MPC823 in transparent mode because it allows the RTS signal of 
one MPC823 to be directly connected to the CD signal of another MPC823. 
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CTSS—CTS Sampling 


0 = The CTS signal is assumed to be asynchronous with the data. It is internally 
synchronized by the serial communication controller and data is then transmitted 
after several serial clock delays. 

1 = The CTS signal is assumed to be synchronous with the data, which speeds up 
operation. In this mode, CTS must transition while the transmit clock is in the low 
state. As soon as CTS is low, data immediately begins transmission. This mode is 
especially useful when connecting an MPC823 in transparent mode since it allows 
the RTS signal of one MPC823 to be directly connected to the CTS signal of 
another MPC823. 


TFL—Transmit FIFO Length 


O = Normal operation. The transmit FIFO is 32 bytes for the serial communication 
controller. 

1 = The transmit FIFO is 1 byte and can be used with character-oriented protocols to 
ensure a minimum FIFO latency at the expense of performance. 





RFW—Receive FIFO Width 


O= Receive FIFO is 32 bits wide for maximum performance. Data is not normally 
written to receive buffers until at least 32 bits are received. This configuration is 
required for HDLC-type protocols and Ethernet, but it is recommended for 
high-performance transparent modes. In this mode, the receive FIFO is 32 bytes 
for the serial communication controller. 

1 = Low-latency operation. The receive FIFO is 8 bits wide and the receive FIFO is a 
quarter its normal size (8 bytes). This allows data to be written to the data buffer 
when a character is received, instead of waiting to receive 32 bits. This 
configuration must be chosen for character-oriented protocols, such as UART. It 
can also be used for low-performance, low-latency, transparent operation, if 
preferred. However, it must not be used with HDLC, HDLC Bus, AppleTalk, or 
Ethernet because it will cause erratic behavior to occur. 


TXSY—Transmitter Synchronized to the Receiver 


This bit is specifically intended for X.21 applications where the transmitted data must ean 
an exact multiple of 8-bit periods after the received data arrives. 


No synchronization between receiver and transmitter (default). 

The transmit bitstream is synchronized to the receiver. Additionally, if RSYN = 1, 
then transmission in the totally transparent mode does not occur until the receiver 
has synchronized with the bitstream and the CTS signal is asserted to the serial 
communication controller. Assuming CTS is already asserted, transmission begins 
eight clocks after the receiver starts receiving data. 


0 
1 
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SYNL—Sync Length (Transparent Mode Only) 


This field determines the operation of the SCC2 receiver that is configured for totally 
transparent operation. See Section 16.9.4 Data Synchronization Register for more 
information. 


00 = The sync pattern in the DSR is not used. An external sync signal is used instead. 

01 = 4-bit sync. The receiver synchronizes on a 4-bit sync pattern stored in the DSR. 
This character and additional syncs can be programmed to be stripped using the 
Sync character in the parameter RAM. The transmitter transmits the entire con- 


a tents of the DSR prior to each frame. 
| 8 , 10 = 8-bit sync. The receiver synchronizes on an 8-bit sync pattern stored in the DSR. 
cee duet Tne transmitter transmits the entire contents of the DSR prior to each frame. 


11 = 16-bit sync. The receiver synchronizes on a 16-bit sync pattern stored in the DSR. 
The transmitter transmits the DSR prior to each frame. 


RTSM—RTS Mode 


0 = Send idles between frames as defined by the protocol and the TEND bit in the 
GSMR_L. RTS is negated between frames (default). 
= Send flags/syncs between frames according to the protocol. RTS is always 
asserted whenever the serial communication controller is enabled. 


wr Note: This bit can be changed on-the-fly. 


RSYN—Receive Synchronization Timing (Transparent Mode Only) 


2 = Normal operation. 
= If CDS = 1, then the CD signal should be asserted on the second bit of the receive 
frame, rather than the first. 


GSMR_L 


(IMMR & OxFFF0000) + 0xA22 
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Bit O—Reserved 
This bit is reserved and should be set to 0. 


EDGE—Clock Edge 


This field determines the clock edge the DPLL uses to adjust the received sample point after 
a jitter occurs in the received signal. These bits are ignored in the UART protocol or the x1 
mode of the RDCR field. 


00 = Both the positive and negative edges are used for changing the sample point (de- 
fault). 

01 = Positive edge. Only the positive edge of the received signal is used for changing 
the sample point. 

10 = Negative edge. Only the negative edge of the received signal is used for changing 
the sample point. 

11 = No adjustment is made to the sample point. 


TCl—Transmit Clock Invert 


O = Normal operation. 

1 = Before it is used, the internal transmit clock (TCLK) is inverted by the serial 
communication controller. This allows the serial communication controller to clock 
data out one-half clock earlier on the rising edge of TCLK rather than on the falling 
edge. In this mode, the serial communication controller offers a minimum and 
maximum “rising clock edge to data” specification. Data output by the serial 
communication controller after the rising edge of an external transmit clock can be 
latched by the external receiver one clock cycle later on the next rising edge of the 
same transmit clock. This option is recommended for Ethernet, HDLC,. or 
Transparent operation when the clock rates are nignet than 8MHz to improve data 
setup time for the external receiver. 


TSNC—Transmit Sense 


This bit indicates the amount of time the internal sense signal stays active after the last 
transition on the RXD2 pin, thus indicating that the line is free. For instance, TSNC can be 
used in the AppleTalk protocol to avoid a spurious CTS-changed interrupt that would 
otherwise occur during the frame sync sequence preceding the opening flags. 


lf the RDCR field is configured to 1x mode, the delay is the greater of the two numbers listed. 
If RDCR is configured to 8x, 16x, or 32x mode, the delay is the lesser of the two numbers 
listed. | 


00 = Infinite—Carrier sense is always active (default). 

01 = 14- or 6.5-bit times as determined by the RDCR field. 

10 = 4- or 1.5-bit times as determined by the RDCR field a for AppleTalk). 
11 = 3- or 1-bit times as determined by the RDCR field. 
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RINV—DPLL Receive Input Invert Data 
This bit must be zero in HDLC bus mode. 


O0= Do not invert. 

1 = Invert the data before sending it to the on- hig DPLL for reception. This setting is 
used to produce FM1 from FMO and NRZI space from NRZI mark. It can also be 
used in regular NRZ mode to invert the datastream. 


TINV—DPLL Transmit Input Invert Data 
This bit must be zero in HDLC bus mode. 


Do not invert. 

Invert the data before sending it to the on- hic DPLL for transmission. This setting 
is used to produce FM1 from FMO and NRZI space from NRZI mark. It can also be 
used in regular NRZ mode to invert the datastream. 


—=— > 


Note: In T1 applications, setting the TINV and TEND bits creates a continuously 
inverted HDLC datastream. 





TPL—Transmit Preamble Length 
This field determines the length of the preamble configured i the TPP field. 


000 = No preamble (default). 

001 = 8 bits (1 byte). 

010 = 16 bits (2 bytes). 

011 = 32 bits (4 bytes). 

100 = 48 bits (6 bytes). Select this setting for Ethernet operation. 
101 = 64 bits (8 bytes). 

110 = 128 bits (16 bytes). 

111 = Reserved. | 


TPP—Transmit Preamble Pattern — | | 
This field determines what, if any, bit pattern should precede the beginning of each transmit 


_ frame. The preamble pattern is sent prior to the first flag/sync of the frame. TPP is ignored 


if the serial communication controller. is programmed to UART mode. The length of the 
preamble is programmed in the TPL field and the preamble pattern is typically transmitted 
to a receiving station that uses a DPLL for clock recovery. The receiving DPLL uses the 
regular pattern of the preamble to help it lock onto the received signal in a short, predictable 
time period. 


00 = All zeros. 


01 = Repetitive 10s. Select this eating for Ethernet operation. | 
10 = Repetitive O1s. 
11 = All ones. Select this setting for LocalTalk operation. 
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TEND—Transmitter Frame Ending 


This bit is specifically intended for NMSI transmitter peainae of the DPLL. This bit 
determines whether the TXD2 signal should idle in a high state or in an encoded ones state 
(high or low). It can, however, be used with other encodings besides NMSI. 


0 = Default operation. The TXD2 signal is only encoded when data is transmitted, 
including the preamble and opening and closing flags/syncs. When no data is 
available to transmit, the signal is driven high. 

1 = The TXD2 signal is always encoded, even when idles are transmitted. 


TDCR—Transmit Divide Clock Rate 


This field determines the divider rate of the transmitter. If the DPLL is not used, the 1x value 
should be chosen, except in asynchronous UART mode where 8x, 16x, or 32x must be 
chosen. You should program TDCR to equal RDCR in most applications. If the DPLL is used 
in the application, the selection of TDCR depends on the encoding. NRZI usually requires 
1x, whereas FMO/FM1, Manchester, and Differential Manchester allow 8x, 16x, or 32x. The 
8x option allows highest speed, whereas the 32x option provides the greatest resolution. 


TDCR is usually equal to RDCR so that the same clock frequency source can control both 
the transmitter and receiver. 


00 = 1x clock mode. Only NRZ or NRZI encodings are allowed. 
01 = 8x clock mode. 

10 = 16x clock mode. Normally chosen for UART and AppleTalk. 
11 = 32x clock mode. | 


RDCR—Receive DPLL Clock Rate 


This field determines the divider rate of the receive DPLL. If the DPLL is not used, the 1x 
value should be chosen, except in asynchronous UART mode where 8x, 16x, or 32x must 
be chosen. You should program this field to equal TDCR in most applications. 


lf the DPLL is used in the application, the selection of RDCR depends on the encoding. NRZI 
usually requires 1x, whereas FMO, FM1, Manchester, and Differential Manchester allow 8x, 
16x, or 32x. The 8x option allows highest speed, whereas the 32x option provides the © 
greatest resolution. ee 


00 = 1x clock mode. Only NRZ or NRZI decodings are allowed. . 
01 = 8x clock mode. 

10 = 16x clock mode. Normally chosen for UART and mpplet ans 
11 = 32x clock mode. 


MOTOROLA MPC823 USER’S MANUAL | 16-167 





fae 
a 
5o 
_= 
ea 
So 
= 
50: 
=O 
of 
Oona 





Bg 
a © Ba 
2 
_ me 
Ba 
va > 
ie 
— 
roRe) 
go= 
[ ened ‘ 





Communication Processor Module 


RENC—Receiver Decoding Method 


000 = NRZ (default setting if DPLL is not used). 
001 = NRZI Mark (set RINV also for NRZI space). 
010 = FMO (set RINV also for FM1). 
011 = Reserved. 
- 100 = Manchesier. 
101 = Reserved. 
110 = Differential Manchester (Differential | Bi-phase- L). 
111 = Reserved. 


“C Note: Select NRZ if the DPLL is not used. You should program this bit io equal TENC | 
in most applications. However,.do not use this internal DPLL for Ethernet mode. 


TENC—Transmitter Encoding Method 


000 = NRZ (default setting if DPLL is not used). 

001 = NRZI Mark (set TINV also for NRZI space). 
010 = FMO (set TINV also for FM1). , 
011 = Reserved. 

100 = Manchester. 

101 = Reserved. 

110 = Differential Manchester (Dierenta Bi- “phase- L). 
111 = Reserved. 


Note: Select NRZ if the DPLL is not used. You should program this bit to equal RENC 
in most applications. However, do not use this internal DPLL for Ethernet mode. 


DIAG—Diagnostic Mode 
The data received enters the RXD2 pin and the transmit data is shifted out through the TXD2 
pin. The serial communication controller uses the modem signals to automatically enable or 


disable transmission and reception. These timings are shown in 
Section 16.9.10 Controlling SCC2 Timing. 


In local loopback mode, the transmitter output is internally connected to the receiver input, 
while the receiver and the transmitter operate normally. The value on the RXD2 pin is 
ignored. Data can be programmed to appear on the TXD2 or the port A register can be 
programmed to make the TXD2 pin high. See Section 16.14 The Parallel I/O Ports for 
more information. The RTS pin can also be programmed to be disabled in the appropriate 
parallel I/O register. In the SDMA field of the SIMODE register, the L1TXDA and L1RQA 
signals can be programmed to be either asserted normally or to remain inactive. See 
Section 16.7.5.2 Serial Interface Mode Register for more information. 
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When using local loopback mode, the clock source for the transmitter and receiver must be 
the same. Thus, the same baud rate generator or external CLKx pin can be used for both 
the transmitter and receiver. Separate CLKx pins can be used with the transmitter and 
receiver as long as the CLKx pins are connected to the same external clock signal source. 


In automatic echo mode, the channel automatically retransmits the received data on a 
bit-by-bit basis using whatever receive clock is provided. The receiver operates normally 
and receives data if CD is asserted. The transmitter simply transmits the received data. 
In this mode, the CTS signal is ignored. The echo function can be implemented in the 
software by receiving buffers from a serial communication controller, linking them to TX 
buffer descriptors, and then transmitting them back out of that serial communication 
controller. 


In loopback/echo mode, loopback and echo operation occur simultaneously. The CD and 
CTS pins are ignored. Refer to the loopback bit description for clocking requirements. 


00 = Normal operation. The CTS and CD signals are under automatic control. 
01 = Local loopback mode. 

10 = Automatic echo mode. 

11 = Loopback and echo mode. 


“Oo Note: If you prefer external loopback, the DIAG field should be selected for normal 

| | operation and an external connection should be made between the TXD2 and 
RXD2 pins. Clocks can be generated internally using a baud rate generator or 
generated externally. You can physically connect the appropriate control signals 
or the port C register can be used to cause the CD and CTS pins to be 
permanently asserted to the serial communication Cantonese 


ENR—Enable Receive 


This bit enables the receiver hardware state machine for the serial communication — 
controller. When ENR is cleared, the receiver is disabled and any data in the receive FIFO 
is lost. If ENR is cleared during reception, the receiver aborts the current character. ENR 
may be set or cleared, regardless of whether the serial clocks are present. Refer to 
Section 16.9.14 Disabling the SCC2 On-the-Fly for a description of how to disable and 
reenable the serial communication controller. | 


Note: The serial communication controller that controls reception provides other tools 
besides the ENR bit. Some of these tools include the ENTER HUNT MODE 
command, CLOSE RX BD command, and the E bit of the RX buffer descriptor. 
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ENT—Enable Transmit 


This bit enables the transmitter hardware state machine for this ssialc communication 
controller. When ENT is cleared, the transmitter is disabled. If ENT is cleared during 
transmission, the transmitter aborts the current character and the TXD2 pin returns to the 
idle state. Data already in the transmit shift register is not transmitted. ENT can be set or 
cleared, regardless of whether the serial clocks are present. Refer to 

Section 16.9.14 Disabling the SCC2 On-the-Fly for a description of how to properly 
disable and reenable the serial communication controller. 


“TZ Note: The serial communication controller that controls transmission provides other 

7 tools besides the ENT bit. These tools include the STOP TRANSMIT command, . 
GRACEFUL STOP TRANSMIT command, RESTART TRANSMIT command, 
the freeze option in UART mode, CTS flow control open in UART mode, and 
the R bit of the TX buffer descriptor. 


MODE—Channel Protocol Mode 


0000 = HDLC. 
0001 = Reserved. 
0010 = AppleTalk/LocalTalk. 

0011 = SS7. Reserved for RAM microcode. 
0100 = UART. 

0101 = Profibus. Reserved for RAM microcode. 
0110 = ASYNC HDLC/IrDA. | 
0111 =V.14. Reserved for RAM microcode. 
1000 = Reserved. 
1001 = DDCMP. Reserved for RAM microcode. 
1010 = Reserved. 
1011 = Reserved. 
1100 = Ethernet. 
11xx = Reserved. 


16.9.3 Protocol-Specific Mode Register _ 


The functionality of the serial communication controller varies according to the protocol © 
selected by the MODE field in the GSMR_L. The serial communication controller has an 
additional 16-bit, memory-mapped, read/write protocol-specific mode register (PSMR) that 
configures it specifically for a chosen mode. Since each protocol has specific requirements, 
the PSMR bits are different for each implementation. A detailed description of each of the 
PSMR bits is contained within each specific SCC2 protocol. 
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16.9.4 Data Synchronization Register 


The serial communication controller has a 16-bit, memory-mapped, read/write data 
synchronization register (DSR) that specifies the pattern used in the frame synchronization 
procedure of the synchronous protocols. In the UART protocol, it is used to configure 


fractional stop bit transmission. In the Transparent protocol, it should be programmed with © 
the preferred Sync pattern. In the Ethernet protocol, it should be programmed with 0xD555. — 
At reset, it defaults to Ox7E7E (two HDLC flags), so it does not need to be written for HDLC | 
mode. When the DSR is used to send out syncs (such as in transparent mode), the contents - 


of the DSR are always transmitted LSB first. 


DSR 


a 
PRP REP PPP apy 
CCS Cid” 


(IMMR & OxFFF0000) + 0xA2E 





16.9.5 Transmit-on-Demand Register 


If no frame is currently being transmitted by the serial communication controller, the RISC © 


microcontroller periodically polls the R bit of the next TX buffer descriptor to see if you have 
requested a new frame/buffer to be transmitted. This polling algorithm depends on the serial 


communication controller configuration, but occurs every 8 to 32 serial transmit clocks. You . 


can, however, request that the RISC microcontroller begin processing the new frame/buffer 
immediately, without waiting until the normal polling time. To obtain immediate processing, 
the TOD bit in the transmit-on-demand register (TODR) i is set after the R bit is set in the TX 
buffer descriptor. 


This feature, which decreases the transmission latency of the transmit buffer/frame, is — 
particularly useful in LAN-type protocols where maximum interframe GAP times are limited 
by the protocol specification. Since the transmit-on-demand feature gives high priority to the 
specified TX buffer descriptor, it can conceivably affect the servicing of the receive FIFO. 
Therefore, it is recommended that you only use the transmit-on-demand feature when a 


high-priority TX buffer descriptor has been prepared and if a sufficient amount of time has | 


passed since the serial communication controller was transmitted. 
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Communication Processor Module 


The TOD bit does not need to be set if a new TX buffer descriptor is added to the circular 
queue or if other TX buffer descriptors in that queue have not finished transmitting. Once 
they are finished, however, the new TX buffer descriptors are processed. The first bit of the 
frame will typically be clocked out 5-6 bit times after the TOD bit has been set to 1. 


TODR ~— 


a 





TOD—Transmit on Demand 


O = Normal operation. 

1 = The RISC microcontroller gives high priority to the current TX buffer descriptor and 
does not wait the normal polling time to check that the TX buffer descriptor’s R bit 
has been set. Instead, it begins panes the frame. This bit is automatically 
cleared after one serial clock. 


Bits 1-15—Reserved © 
‘These bits are reserved and should be set to 0. 


16. 9. 6 SCC2 Buffer Descriptor Operation 


Data associated with the serial communication controller channel transmitter and receiver 
is stored in buffers and each buffer is referenced bya buffer descriptor that can be located 


anywhere in internal memory. The MPC823 internal memory has enough space for 224 
buffer descriptors (BDs) to be shared between the universal serial bus, serial 
communication controller, serial managment controllers, serial peripheral interface, and I?C 
controller. However, you must define how the buffer descriptors will be allocated to the serial 
channel's transmitter or receiver. You can select 100 buffer descriptors for the SCC2 
receiver or 20 buffer descriptors for the transmitter. 


The buffer descriptor table forms a circular queue with a programmable length. You can 
program the start address of each channel buffer descriptor table in the internal memory. In 
addition, you can allocate the parameter area of an unused channel to the other used 
channels as buffer descriptor tables or actual buffers. See Figure 16-63 for details. 


= Note: The communication processor module sets all the status bits in these buffer 
| descriptors. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 

bit is only set when a parity error occurs. 
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The format of the buffer descriptors is the same for each serial communication controller 
mode of operation and for transmit and receive. The first word in each buffer descriptor 
contains a status and control word that determines the buffer descriptor’s table length. Only 
this first field, which contains the status and control bits, differs for each protocol. The 
second word determines the data length referenced to this buffer descriptor and the last two 
words in the buffer descriptor contain a 32-bit address pointer that points to the actual buffer 
in memory. 


DATALENGTH : 
HIGH-ORDER DATA BUFFER POINTER 
LOW-ORDER DATA BUFFER POINTER 





R/E—Ready/Empty 

Ready (Transmitter): 

O= The data buffer associated with this buffer descriptor is not ready to be transmitted. 
You are free to manipulate this buffer descriptor or its associated data buffer. The 
communication processor module clears this bit after the buffer is transmitted or 
after an error condition is encountered. 

1 = The data buffer, which you must prepare for transmission, has not been 
transmitted yet or is currently being transmitted. You cannot write any fields of this 
buffer descriptor once this bit is set. 


Empty (Receiver): 

O= The data buffer associated with this RX buffer descriptor has been filled with data 
or reception has been aborted because of an error condition. The core is free to 
examine or write to any fields of this RX buffer descriptor. The communication 
processor module does not use this buffer descriptor again as long as the E bit is 
zero. 

1 = The data buffer associated with this buffer descriptor is empty or is currently 
receiving data. This RX buffer descriptor and its associated receive buffer are 
owned by the communication processor module. Once the E bit is set, the core 
should not write any fields of this RX buffer descriptor. 


W—Wrap | | | 

0 = This is not the last buffer descriptor in the buffer descriptor ring. 

1 = This is the last buffer descriptor in the buffer descriptor ring. After this buffer has 
been used, the communication processor module will transmit (receive) data from 
the first buffer descriptor that TBASE (RBASE) points to in the table. The number 
of TX buffer descriptors in the ring are programmable and determined only by the 
W bit and overall space constraints of the dual-port RAM. | 
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I—Interrupt 


0 = No interrupt is nenoraied fee this batter is eenieed: 

1 = The specific RX or TX bit in the protocol event register is set when this biter is 
serviced by the communication processor module. These bits can cause an 
interrupt when enabled by the mask register. : | 


For ame oriented protocols, a message can reside i in as many buffers as necessary. Each 
buffer has a maximum length of (64K—1) bytes. The communication processor module does 
not assume that all buffers of a single frame are currently linked to the buffer descriptor 
table. It does assume, however, that the unlinked buffers are provided by the core in time to 
be transmitted or received. When this does not occur, an error condition is reported by the 
communication processor module. An underrun error is reported when data is transmitted 
and a busy error is reported when data is received. . 


DUAL- PORT RAM EXTERNAL MEMORY 


TX BUFFER DESCRIPTORS ~ 
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Figure 16-63. SCC2 Memory Structure 


16-174 MPC823-USER’S MANUAL | MOTOROLA 


Communication Processor Module 


All protocols can have their buffer descriptors point to data buffers that are located in the 
internal dual-port RAM. However, because the internal RAM is being used for buffer _ 
descriptors, it is customary for the data buffers to be located in external RAM, especially if 
the data buffers are large. In most instances, the internal U-Bus is used to transfer data to 
the data buffer. | 


The communication processor module processes the TX buffer descriptors ina 
straightforward manner. Once the transmit side of a serial communication controller is 
enabled, it starts with the first buffer descriptor in that SCC2 transmit table. Once the 
communication processor module detects that the R bit is set in the TX buffer descriptor, it 
starts processing the buffer. The communication processor module detects that the buffer 
descriptor is ready when it polls the R bit or when you try to write to the TODR. Once the 
data from the buffer descriptor has been placed in the transmit FIFO, the communication 
processor module moves on to the next buffer descriptor, again waiting for that buffer 
descriptor R bit to be set. Thus, the communication processor module does no look-ahead 
buffer descriptor processing, nor does it skip over buffer descriptors that are not ready. 


When the communication processor module sees the W bit set in a buffer descriptor, it goes 
back to the beginning of the buffer descriptor table after processing of the buffer descriptor 
is complete. After using a buffer descriptor, the communication processor module normally 
sets the R bit to 0, thus, the communication processor module does not use a buffer 
descriptor twice until the buffer descriptor has been confirmed by the core. The one 
exception to this rule is that the MPC823 supports an option for repeated transmission called 
continuous mode, whereby the R bit stays set to 1. This is available in some protocols. 


The communication processor module uses the RX buffer descriptors in a similar fashion. 

Once the receive side of a serial communication controller is enabled, it starts with the first 
buffer descriptor in that SCC2 RX buffer descriptor table. Once data arrives from the serial 
line into the serial communication controller, the communication processor module performs 
certain required protocol processing on the data and moves the resultant data to the data 

buffer pointed to by the first buffer descriptor. Use of a buffer descriptor is complete when 

there is no more room left in the buffer or when certain events occur, such as detection of 

an error or an end-of-frame. Whatever the reason, the buffer is then closed and additional 
data is stored using the next buffer descriptor. 


Whenever the communication processor module needs to begin using a buffer descriptor 
because new data is arriving, it checks the E bit of that buffer descriptor. If the current buffer 
descriptor is not empty, it reports a busy error. However, it does not move from the current 
buffer descriptor until it is empty. When the communication processor module discovers the 
W bit set in a buffer descriptor, it goes back to the beginning of the buffer descriptor table 
after processing is complete and after using a buffer descriptor, the communication 
processor module sets the E bit to 0 and never uses a buffer descriptor twice until it has been 
processed by the core. The one exception to this rule is that the MPC823 supports an option 
for repeated reception called continuous mode, whereby the E bit stays set to 1. This is 
available in some protocols. | 


MOTOROLA ‘MPC823-USER’S MANUAL | 16-175 


Lu 

poe | 

a 
50 
—— 
co 
28 
= 
> 
=O 
ae 
on. 





Communication Processor Module 


16.9.7 SCC2 Parameter RAM Memory Map 


The serial communication controller parameter RAM area begins at an offset from the SCC2 
base area. The protocol-specific portions of the SCC2 parameter RAM are discussed in the 
specific protocol descriptions and the part that is common to all serial communication _ 
controller protocols is shown in Table 16-24. | 


You need to initialize certain parameter RAM values before the serial communication 
controller can be enabled. Other values are initialized or written by the communication 
processor module. Once initialized, most parameter RAM values do not need to be 


Pa : accessed in your software because most of the activity is centered around the transmit and 
QO receive buffer descriptors, not the parameter RAM. However, if you do access the parameter 
eet eae RAM, the following regulations should be noted: — 


_¢ The parameter RAM can be read at any time. 


e The parameter time values related to the SCC2 transmitter can only be written 
whenever the transmitter is disabled after a STOP TRANSMIT command and before a 
RESTART TRANSMIT command or after the buffer/frame finishes transmitting as a 
result of the execution of a GRACEFUL STOP TRANSMIT command and before a 
RESTART TRANSMIT command is executed. 


e The parameter RAM values related to the SCC2 receiver can only be written when the 
receiver is disabled. 


Refer to Section 16.9.14 Disabling the SCC2 On-the-Fly for more information. 
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Table 16-24. SCC2 Parameter RAM Memory Map For All Protocols 


[rooness [wane [wore [econo 


NOTE: You are only responsible for initializing the items in bold. 
SCC2 Base = (IMMR & OxFFFFOO000) + 0x3D00. 































e RBASE and TBASE—These entries are where the dual-port RAM starts the SCC2 
receive and transmit buffer descriptors. They provide a great deal of flexibility in how 
buffer descriptors for the serial communication controller are partitioned. By selecting 
RBASE and TBASE entries for the serial communication controller and by setting the 
W bit in the last buffer descriptor in each buffer descriptor list, you can select how many | 
buffer descriptors to allocate for the transmit and receive side of the serial 
communication controller. However, you must initialize these entries before enabling 
the corresponding channel. | 


Note: RBASE and TBASE should contain a value that is divisible by eight. 
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e RFCR and TFCR—There are two function code registers for the SCC2 channel—one 
for receive data buffers and one for transmit data buffers. The function code entry 
contains the value that you want to appear on the AT pins when the associated SDMA 
channel accesses memory. It also controls the byte-ordering convention for transfers. 


RFCR 





SCC2 BASE + 0x00 | 


Bits O—2—Reserved 
These bits are reserved and should be set to 0. 


BO—Byte Ordering 


You should set these bits to select the required byte ordering of the data buffer. lf this 
field is modified on-the-fly, it takes effect at the beginning of the next frame or the next 
buffer descriptor. 


00 = The DEC/Intel convention is used for byte ordering (swapped operation) and 
is also called little-endian byte ordering. The transmission order of bytes within 
a buffer word is reversed in comparison to the Motorola mode. This mode is 
supported only for 32-bit port size memory. 

01 = PowerPC little-endian byte ordering. As data is transmitted onto the serial line 
from the data buffer, the least-significant byte of the buffer double-word 
contains data to be transmitted earlier than the most-significant byte of the 
same buffer double-word. | 
Motorola byte ordering (normal operation) is also called big-endian byte 

ordering. As data is transmitted onto the serial line from the data buffer, the 
most-significant byte of the buffer word contains data to be transmitted earlier 
than the least-significant byte of the same buffer word. 


_AT—Address Type 


These bits contain the function code value used during the SDMA channel memory 
access. ATO is driven with a 1 to identify this SDMA channel access as a DMA type. 


1X 


TFCR 





SCC2 BASE + 0x02 
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Bits 0-2—Reserved | 
These bits are reserved and should be set to 0. 


BO—Byte Ordering 


You should set these bits to select the required byte ordering of the data buffer. If this 
field is modified on-the-fly, it takes effect at the beginning of the next frame or the next 
buffer descriptor. 


00 = The DEC/Intel convention is used for byte ordering (swapped operation) and 
is also called little-endian byte ordering. The transmission order of bytes within Pe 
a buffer word is reversed in comparison to the Motorola mode. This mode is og 
supported only for 32-bit port size memory. 

01 = PowerPC little-endian byte ordering. As data is transmitted onto the serial line 
from the data buffer, the least-significant byte of the buffer double-word 
contains data to be transmitted earlier than the most-significant byte of the 
same buffer double-word. 

1X = Motorola byte ordering (normal operation) is also called big-endian byte 

_ ordering. As data is transmitted onto the serial line from the data buffer, the 
most-significant byte of the buffer word contains data to be transmitted earlier 
than the least-significant byte of the same buffer word. | 


ATt—Address Type 


These bits contain the function code value used during this SDMA channel memory 
access. AT0 is driven with a 1 to identify this SDMA channel access as a DMA type. 





e MRBLR—The serial communication controller has one maximum receive buffer length 
register to define the receive buffer length. The MRBLR defines the maximum number 
of bytes that the MPC823 writes to a receive buffer on the serial communication 
controller before it moves on to the next buffer. The MPC823 can write fewer bytes to 
the buffer than MRBLR if a condition, such as an error or end-of-frame occurs, but it 
never writes more bytes than the MRBLR value. It follows then, that buffers you supply 
should always be at least as long as the MRBLR. The transmit buffers for the serial 
communication controller are not affected in any way by the value programmed into the 
MRBLR. Transmit buffers can be individually chosen to have varying lengths. The 
number of bytes to be transmitted is chosen by programming the DATA LENGTH field 
in the TX buffer descriptor. 
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Note: The MRBLR is not intended to be dynamically changed while the serial 

| communication controller is operating. However, if it is modified in a single bus 

cycle with one 16-bit move, then a dynamic change in receive buffer length can 

be successfully achieved. This occurs when the communication processor 

- module moves control to the next RX buffer descriptor in the table. Thus, a 

change to MRBLR does not have an immediate effect. To guarantee the exact 

RX buffer descriptor on which the change occurs, you should only change the 

MRBLR while the SCC2 receiver is disabled. The value of MRBLR should be 

greater than zero for all modes. For Ethernet and HDLC mode, the MRBLR 

should be evenly divisible by 4. In transparent mode, the MRBLR should also be 
divisible by 4, unless the RFW bit of the GSMR_H is set to 8 bits. 








¢ RBPTR—The receiver buffer descriptor pointer for each SCC2 channel points to the 
next buffer descriptor the receiver transfers data to when it is in idle state or to the 
current buffer descriptor during frame processing. After a reset or when the end of the 
buffer descriptor table is reached, the communication processor module initializes this 
pointer to the value programmed in the RBASE register. Although you will not usually 
need to write the RBPTR in most applications, you can modify it when the receiver is 
disabled or when you are sure no receive buffer is currently being used. 


e TBPTR—The transmitter buffer descriptor pointer for each SCC2 channel points to the 
. next buffer descriptor the transmitter transfers data from when it is in idle state or to the 
~' current buffer descriptor during frame transmission. After a reset or when the end of the 

buffer descriptor table is reached, the communication processor module initializes this 
pointer to the value programmed in the TBASE register. Although you will not usually 
need to write TBPTR in most applications, you can modify it when the receiver is 
disabled or when you are sure no receive buffer is currently being used. 


e Other General Parameters—You do not need to access these parameters during 

~ normal operation. They are only listed because they provide helpful information for 
experienced users and for debugging purposes. Additional parameters are listed in 
Table 16-24. RPTR and TPTR are updated by the SDMA channels to show the next 

_ address in the buffer to be accessed. TCNT is a down-count value that is initialized with 

_ the TX buffer descriptors data length and decremented with every byte read by the 
SDMA channels. RCNT is a down-count value that is initialized with the MRBLR value 
and decremented with every byte written by the SDMA channels. RSTATE, TSTATE, 
RTMP, TTMP, and reserved areas should only be used by the RISC microcontroller. 


Note: To extract data from a partially full receive buffer, issue the CLOSE RX BD 
command. 
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16.9.8 Handling Interrupts In the SCC2 


Interrupt handling for the SCC2 channel is configured on a global basis in the CPM interrupt 
pending register, CPM interrupt mask register, and CPM in-service register. In each of these 
registers, a bit is used to mask, enable, or report the presence of an interrupt from SCC2. 
The interrupt priority between the serial communication controller is programmable in the 
CPM interrupt configuration register. There is an event register within each puoi of the 
serial communication controller that allows interrupt handling. 


A number of events can cause the serial communication controller to interrupt the processor 
and these events differ slightly depending on the protocol you have selected. These events 
are handled independently between each channel by the SCC2 event and mask registers. 
Events that can cause interrupts because of the CTS and CD modem lines are described in 
Section 16.14.8 Port C Pin Functionality. 


16.9.8.1 SCC2 EVENT REGISTER. The 16-bit memory-mapped SCC2 event (SCCE) 
register is used to report events recognized by the serial communication controller. When 
an event is recognized, the serial communication controller sets the corresponding bit in the 
SCCE, regardless of the corresponding mask bit. A bit is cleared by writing a 1 (writing a 
zero has no effect) and more than one bit can be cleared at a time. This register is cleared 
at reset and can be read at any time. Since each protocol has specific requirements, the 
protocol-specific mode register (PSMR) bits are different for each implementation. A 
detailed description of each of the PSMR bits is contained within each specific protocol. 


16.9.8.2 SCC2 MASK REGISTER. The 16-bit, read/write SCC2 mask (SCCM) register 
allows you to enable or disable interrupt generation using the communication processor 
module for specific events in each SCC2 channel. An interrupt is only generated if the SCC2 
interrupts in this channel are enabled in the CPM interrupt mask register (CIMR). 


If a bit in the SCCM register is zero, the communication processor module does not proceed 
with its usual interrupt handling whenever that event occurs. Anytime a bit in the SCCM 
register is set, a 1 inthe corresponding bit in the SCCE register sets the SCC2 bit in the CPM 
interrupt pending register (CIPR), which is described in Section 16.15 The CPM Interrupt 
Controller. The bit format of the SCCM register is identical to that of the SCCE. Since each 
protocol has specific requirements, the SCCM bits are different for each implementation. A 
detailed description of each of the SCCM bits is contained within each specific protocol. — 


16.9.8.3 SCC2 STATUS REGISTER. The 8-bit, read/write SCC2 status (SCCS) register 
allows you to monitor real-time status conditions on the RXD2 signal. It does not show the 
real-time status of the CTS and CD pins. Their real-time status is available in the port C 
parallel I/O. Since each protocol has specific requirements, the SCCS bits are different for 
each implementation. A detailed description of each of the SCCS bits is contained within 
each specific protocol. : 


MOTOROLA MPC823 USER’S MANUAL 16-181 


Lu 
—_/ 
a 
AS 
—_— 
co. 
2s 
= 
rt} 
=o. 
Oo 
oy a 
oa. 





_‘ Communication Processor Module 


16.9.9 Initializing Serial Communication Controller 


The serial communication controller requires that a number of registers and parameters be 
configured after a power-on reset. Regardless of the protocol you are using, follow inese 
steps to initialize the serial communication controller: 


1. Write the sarallél V0 ports to configure and connect ihe I/O pins to the serial 
communication controller. 


2. The RAID field of the SDCR should be initialized with the appropriate arbitration ID. 


3. Write the port C registers to configure the CTs and CD pins to be in parallel 1/O with 
interrupt capability or to be direct connections to the serial communication controller 
(if modem support is needed). 





4. If the time-slot assigner is used, the serial interface must be configured. If the serial 
~ communication controller is used in NMSI mode, the SICR must still be initialized. 


| Write the GSMR_H and GSMR_L, but do not write the ENT or ENR bits yet. 
Write the PSMR. 
Write the DSR. 


Initialize the required values for the serial communication controller in its parameter 
RAM. 


9. Clear out any current events in 1 the SCCE register (optional). 

10. Write the SCCM register to enable the interrupts in the SCCE register. 
11.Write the CICR to configure the SCC2 interrupt priority. | 

12. Clear out any current interrupts in the CIPR (optional). 

13. Write the CIMR to enable interrupts to the CPM interrupt controller. 
14. Set the ENT and ENR bits in the GSMR_L. 


ONO 


‘The buffer descriptors can have their R or E bits set at any time. Notice that the CPCR does 
not need to be accessed after a power-on reset. The serial communication controller should 
be disabled and reenabled after any dynamic change in its parallel I/O ports or serial 
channel physical interface configuration. A full reset using the RST bit in the CPCR is a 
comprehensive reset that can also be implemented. . 


Follow these lope. to handle an interrupt in the serial communication controller: 


- Once an interrupt occurs, read the SCCE register to find out which source has caused 
_ the interrupt. The SCCE bits that are going to be “handled” in this interrupt handler 
would normally be cleared at this time by writing ones to them. 


2. Process the TX buffer descriptors to reuse them if the TX or TXE bit was set in the 
SCCE register. If the transmit speed is fast or the interrupt delay is long, more than 
one transmit buffer may have been sent by the serial communication controller. Thus, 
it is important to check more than just one TX buffer descriptor during interrupt 
handling. One common practice is to process all TX buffer descriptors in the interrupt 
handler until one is found with its R bit set. 
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3. Extract data from the RX buffer descriptor if the RX, RXB, or RXF bit is set in the SCCE 
register. If the receive speed is fast or the interrupt delay is long, more than one 
receive buffer may have been received by the serial communication controller. Thus, 
it is important to check more than just one RX buffer descriptor during interrupt 
handling. One common practice is to process all RX buffer descriptors in the interrupt 
handler until one is found with its E bit set. 


4. Reset the status bit in the buffer descriptor’s control and status field that is associated 
with the interrupt. These bits do not set reset after each I/O operation. 


5. Clear the SCC2 bit in the CISR. 
6. Execute the rfi instruction. 


16.9.10 Controlling SCC2 Timing 


When the DIAG field of the GSMR_L are programmed to normal operation, the CD and CTS 
signals are automatically controlled by the serial communication controller. It is assumed 
that the TCI bit of the GSMRF_L is cleared, which implies a normal transmit clock operation. 


16.9.10.1 SYNCHRONOUS PROTOCOLS. In synchronous protocols, the RTS pin is 
asserted when the serial communication controller data is loaded into the transmit FIFO and 
a falling transmit clock occurs. At this point, the serial communication controller starts 
transmitting data once the appropriate conditions occur on the CTS pin. In all cases, the first 
bit of data is the start of the opening flag, sync pattern, or preamble. 


Figure 16-64 illustrates that the delay between the RTS pin and data is 0 bit times, 
regardless of how the CTSS bit is set in the GSMR_H. This operation assumes that the CTS 
pin is already asserted to the serial communication controller or that the CTS pin is 
reprogrammed to be a parallel I/O line, in which case the CTS signal to the serial 
communication controller is always asserted. The RTS pin is negated one clock after the last 
bit in the frame. : | . 






TCLK 
TXD2 FT ee 
(OUTPUT) ee 
RTS FIRST BIT OF FRAME DATA LAST BIT OF FRAME DATA 
(OUTPUT) | 
__ | | 
CTS | | | 
(INPUT) | | 


| | 
| 
NOTE: A frame includes opening and closing flags and syncs, if present in the protocol. 


Figure 16-64. RTS Output Delays Asserted for Synchronous Protocols 
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If the CTS pin is not already asserted when the RTS pin is asserted, then the delays to the 
first bit of data depend on when CTS is asserted. Figure 16-65 illustrates that the delay 
between CTS and the data can be approximately 0.5- to 1-bit time or 0-bit times, depending 
on how the CTSS bit is set in the GSMR_H. : 






TCLK 
a TXD2 
| (OUTPUT) / 


7, 


RTS FIRST BIT OF FRAME DATA LAST BIT OF FRAME DATA “ ~ 


(OUTPUT) 








(INPUT) CTS SAMPLED LOW HERE 





~ NOTE: CTSS = 0 in the GSMR. CTSP is a “don't care’. 


TCLK 





TXD2 
(OUTPUT) 






RTS ~ FIRST BIT OF FRAME DATA LAST BIT OF FRAME DATA 


(OUTPUT) 


| | 
TS | 
(INPUT) . | 
(— | 
i 








| 
NOTE: CTSS = 1 in the GSMR. CTSP is.a “don't care". 


Figure 16-65. CTS Output Delays Asserted for Synchronous Protocols 
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lf the CTS pin is programmed to envelope the data, it must remain asserted during frame 
transmission or a CTS lost error occurs. Negation of the CTS pin forces the RTS pin high 
and the transmit data to an idle state. If the CTSS bit in the GSMR_H is zero, the CTS pin 
must be sampled by the serial communication controller before a CTS lost is recognized. 
Otherwise, the negation of CTS immediately causes the CTS lost condition. Refer to 
Figure 16-66 for details. 





TCLK aan 
1 | 
Us tt | DATA FORCED HIGH 
(OUTPUT) ii ES 
| 
RTS ! ‘FIRST BIT OF FRAME DATA | RTS FORCED HIGH 
(OUTPUT) ! 
| I 
CTS HT a _ 
(INPUT) ) '~<———— CTS SAMPLED LOWHERE = CTS SAMPLED HIGH HERE ! 
if! 
| 
1 | I 
1 oi I 
NOTE: CTSS =0 in the GSMR. CTSP = 0 or no CTS lost can occur. CTS LOST SIGNALED IN FRAME BD 


TCLK 


TXD2 
(OUTPUT) 


rai | FIRST BIT OF FRAME DATA | | RTS FORCED HIGH 








| 
1 I 

ee ; cae | 

CTS yo : ! 

(INPUT) ! | i 
l ] 
, : ! : 
NOTE: CTSS = 1 in the GSMR. CTSP = 0 or no CTS lost can occur. CTS LOST SIGNALED IN FRAME BD 


Figure 16-66. CTS Lost in Synchronous Protocols 


Note: If the CTSS bit in the GSMR_H is set, all CTS transitions must occur while the 
transmit clock is low. 
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Reception delays are determined by the CD pin as illustrated in Figure 16-67. If the CDS bit 
in the GSMR_H is zero, then the CD pin is sampled on the rising receive clock edge prior to 


‘data being received. If the CDS bit in the GSMR_H is 1, then the CD pin transitions cause 


data to be immediately gated into the receiver. 


RCLK 


~ RXD2 











t 

| 

_ (INPUT) ! 

! 
CD FIRST BIT OF FRAME DATA LAST BIT OF FRAME DATA | 
(INPUT) ! | i: 
ae CDSAMPLEDLOWHERE  ~—_— CD SAMPLED HIGH HERE —>1 
‘ —_ I 

NOTES: 


1. CDS =Oin the GSMR; CDP = 0. 
2. If CD is negated prior to the last bit of the receive frame, CD lost is signaled in the frame buffer descriptor. 
3. If CDP = 1, CD lost cannot occur and CD negation has no effect on reception. 


RCLK 











RXD2 
(INPUT) y 
I 
CD | FIRST BIT OF DATA IN FRAME LAST BIT OF FRAME DATA ! 
(INPUT) | | | 
1 —_ ; 
| «<—_————— CD ASSERTION IMMEDIATELY CD NEGATION IMMEDIATELY —>1 
| GATES RECEPTION HALTS RECEPTION ! 
NOTES: 


1. CDS =1 in the GSMR; CDP = 0. 
2. If CD is negated prior to the last bit of the receive frame, CD lost is signaled in the frame buffer piel a 
3. If CDP = 1, CD lost cannot occur and CD negation has no effect on reception. 


Figure 16-67. Using CD to Control Synchronous Protocol Reception 


If the CD pin is programmed to envelope the data, it must remain asserted during frame 
transmission or a CD lost error occurs. Negation of the CD pin terminates reception. If the 
CDS bit in the GSMR_H is zero, the CD pin must be sampled by the serial communication 
controller before a CD lost error is recognized. Otherwise, the negation of CD immediately 
causes the CD lost condition to occur. 





Note: lf the CDS bit in the GSMR_H is set, all CD transitions must occur while the 
receive clock is low. 
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16.9.10.2 ASYNCHRONOUS PROTOCOLS. In asynchronous protocols, the RTS pin is 
asserted when SCC2 data is loaded into the transmit FIFO and a falling transmit clock 
occurs. The CD and CTS pins can be used to control reception and transmission in the same 
manner as the synchronous protocols. The first bit of data transmission in an asynchronous 
protocol is the start bit of the first character. In addition, the UART protocol has an option for 
CTS flow control as described in Section 16.9.15 The SCC2 in UART Mode. 


lf CTS is already asserted when RTS is asserted, transmission begins in two additional 

bit times. However, if CTS is not already asserted when RTS is asserted and CTSS = 0, then 
transmission begins in three additional bit times. If CTS is not already asserted when RTS 
is asserted and CTSS = 1 in the GSMF_H, then transmission begins in two additional bit 
times. 


16.9.11 Digital Phase-Locked Loop Operation 


Each SCC2 channel includes a digital phase-locked loop (DPLL) that is used to recover 
clock information from a received datastream. For applications that provide a direct clock 
source to the serial communication controller, the DPLL can be bypassed if it is programmed 
to do so in the GSMR_L. The DPLL must not be used when the serial communication 
controller is programmed to Ethernet and it is optional for other protocols. The DPLL receiver 
block diagram is illustrated in Figure 16-68 and the transmitter block diagram is in 

Figure 16-69. 7 


The DPLL can be driven by an external clock or one of the baud rate generator outputs and 
they should be approximately 8x, 16x, or 32x the data rate, depending on the encoding or 
decoding preferred. The DPLL uses this clock, along with the datastream, to construct a 
data clock that can be used as the SCC2 receive and/or transmit clock. In all modes, the 
DPLL uses the input clock to determine the nominal bit time. 


At the beginning of operation, the DPLL is in search mode, whereas the first transition resets 
the internal DPLL counter and begins DPLL operation. While the counter is counting, the 
DPLL watches the incoming datastream for transitions and when a transition is detected, the 
DPLL makes a count adjustment to produce an output clock that tracks the incoming bits. 
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RENC 
RDCR 0 
- 7 _HSRCLK], —— LRELE 
EDGE DPLL ‘| CARRIERSNC _ 
TSNC RECEIVER NOISE S 
RINV HUNTING | 
RXD2 DECODED DATA X1 MODE 
HSRCLK | | | 
0 
RINV SCCRDATA 


X1 MODE 





HSRCLK 


Figure 16-68. DPLL Receiver Block Diagram 





; | 
HSTCLK |, — 
_—_TENC a 
_TDCR | 
TEND DPLL | X1 MODE 
TRANSMITTER | DQ 
HSTCLK = : . 
| TXEN 
HSTCLK | Gy 
ENCODED 
DATA 
SCCT DATA | 0 
TINV ) > 0 D Q 


TXD2 








X1 MODE 
TENC = NRZI 






Figure 16-69. DPLL Transmitter Block Diagram 
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The DPLL has a carrier-sense signal that indicates when there are data transfers on the 
RXD2 signal. Using the TSNC field of the GSMF_L, this signal is asserted as soon as a 
transition is detected on RXD2 and it is negated after a programmable number of clocks 
have been detected with no transitions. : 


To prevent itself from locking on the wrong edges and to provide fast synchronization, the 
DPLL should receive a preamble pattern before it receives the data. In some protocols, the 
preceding flags or syncs are used. However, some protocols require a special pattern, such 
as alternating ones and zeros. When a transmission occurs, the serial communication 

controller can generate preamble patterns as programmed in the TPP and TPL bits of the pS 
GSMR_L. Ss 





Table 16-25. Preamble Patterns for Decoding Methods 


LENGTH REQUIRED 


In addition, the DPLL can be used to invert the datastream of a reception or transmission. 
This feature is available in all encodings, including the standard NRZ data format. Also, 
when the transmitter is idle, the DPLL can either force the TXD2 signal to a high voltage or 
continue encoding the data supplied to it. The DPLL is used for UART encoding/decoding, 
which gives you the option of selecting the divide ratio in the UART decoding process (8x, 
16x, or 32x). Typically, 16x option is used. 










The maximum data rate that can be supported with the DPLL is 3.125MHz when operating 
with a 25MHz system clock, assuming that the 8x option is chosen 

(25MHz + 8 = 3.125MHz). Thus, the frequency applied to the CLKx pin or generated by an 
internal baud rate generator may be up to 25MHz on a 25MHz MPC823, if the DPLL 8x, 16x, 
or 32x options are used. | | 


Note: The 1:2 ratio of GCLK1 to the serial clock does not apply when the DPLL is used 
to recover the clock in the 8x, 16x, or 32x modes. Synchronization occurs 
internally after the receive clock is generated by the DPLL. Therefore, even the 
fastest DPLL clock generation (the 8x option) easily meets the required 1:2 ratio 
Clocking limit. 
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16.9.11.1 ENCODING AND DECODING DATA WITH A DPLL. The serial communication 

— controller contains a digital phase-locked loop unit that can be programmed to encode and 
decode SCC2 data as NRZ, NRZI Mark, NRZI Space, FMO, FM1, Manchester, and 
Differential Manchester. Examples of the different encoding methods are illustrated | in. 
Figure 16-70. 


DATA | 


 NRZ 





eae NRZI MARK 


NRZI SPACE 


FMO 
FM1 


MANCHESTER 


Tae 
rating 
ee LE 
wie 
SESE 


DIFFERENTIAL 
MANCHESTER 


Figure 16-70. DPLL Encoding Examples. 


lf you do not want to use the DPLL, you can choose NRZ coding in the RENC and TENC 
bits in the GSMR_ L. The coding is defined as follows: 


¢ NRZ—A one is represented by a nigh eve! for the duration of the bit and a zero is 
represented by a low level. 


¢ NRZI Mark—A one is represented by no transition at all. A zero is represented bya 
transition at the beginning of the bit (the level present in the preceding bit is reversed). 

e NRZI Space—A one is represented by a transition at the beginning of the bit (the level 
present in the preceding bit is reversed). A zero is represented by no transition at all. 


¢ FMO—A one is represented by a transition only at the beginning of the bit. A zero is 
represented by a transition at the on of the bit and another transition at the 
center of the bit. 


FM1—A one is represented by a transition at the pacianitig of the bit and another 
transition at the center of the bit. A zero is represented by a transition only at the 
beginning of the bit. 
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e Manchester—A one is represented by a high to low transition at the center of the bit. A 
zero is represented by a low to high transition at the center of the bit. In both cases there 
may be a transition at the beginning of the bit to set up the level required to make the 
correct center transition. : 


e Differential Manchester—A one is represented by a transition at the center of the bit 
with the opposite direction from the transition at the center of the preceding bit. A zero 
is represented by a transition at the center of the bit with the same polarity from the 
transition at the center of the preceding bit. 


16.9.12 Clock Glitches 


A clock glitch occurs when an input clock signal transitions between a one and zero state 
two times, in a time period small enough to violate the minimum high or low time 
specification of the input clock. They also occur when excessive noise is present on a slowly 
rising or falling signal. 


This can be a potential problem for many communication systems. Not only can glitched 
clocks cause systems to experience errors, but they can also cause undetected the errors. 
Systems that supply an external clock to a serial channel are often susceptible to glitches 
from noise, connecting or disconnecting the physical cable from the application board, or 
excessive ringing on a clock line. | 


The serial communication controller has a special circuit designed to detect glitches that 
occur within the system. The glitch circuit is designed to detect glitches that could cause the 
serial communication controller to transition to the wrong state. This status information can 
be used to alert the system of a problem at the physical layer. The glitch detect circuit is not 
a specification test, so if you develop a circuit that does not meet the input clocking 
specifications for the serial communication controller, erroneous data can be received or 
transmitted that is not indicated by the glitch detection logic. Conversely, if a glitch indication 
is signaled, it does not guarantee that erroneous data was received or transmitted. 
Regardless of whether the DPLL is used, the received clock is passed through a noise filter 
that eliminates any noise spikes that affect a single sample. This sampling is enabled using 
the GDE bit of the GSMR_H. 


If a spike is detected, a maskable receive or transmit glitched clock interrupt is generated in 
the event register of the SCC2 channel. Although you can either reset the SCC2 receiver or 
transmitter or continue operation, the statistics on clock glitches should be kept for later. 
evaluation. The glitch status indication can also be used as a debugging aid during the early 
phases of prototype testing. 
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16.9.13 DPLL and Serial Infra-Red Encoder/Decoder 


IrDA is a family of specifications intended to facilitate the interconnection of computers and 
peripherals using a directed half duplex serial infrared physical communications medium. 
The infra-red data association (IrDA) physical layer standard version 1.1 specifies three 
modes of operation, each one with a distinct modulation scheme and signaling rate. 


e Low speed mode—2.4Kb/s to 115.2Kb/s 


e Middle speed mode—0.576 Mb/s or 1.152 Mb/s 
e High speed mode—4 Mb/s 
Figure 16-71 illustrates how to implement a general infra-red link with the MPC823 using the 


serial communication controller, IrDA encoder/decoder module, and external IrDA — 
transducer module. | 
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Figure 16-71. Serial IrDA Link 


The IrDA DPLL is driven by one of the baud rate generator outputs or by an external clock 
called a high-speed receive/transmit clock (HSRCLK/HSTCLK) that is used as a reference 
clock for the IrDA DPLL. In low- and middle-speed modes, the HSRCLK and HSTCLK 
frequency should be 16x the serial frequency. In high-speed mode, the ratio between the 
HSRCLK/HSTCLK frequency and the serial frequency depends on the IrDA DPLL mode, 
which is currently 12x the serial frequency. Therefore, for high-speed mode IrDA operation 
from an external clock , a 48MHz frequency must be provided. It you are using a source for 
HSRCLK and HSTCLK, the minimum system frequency must be 48MHz. See 

Section 16.9.20.5 Programming Model for more information. | 
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16.9.14 Disabling the SCC2 On-the-Fly 


lf you do not need the serial communication controller for a while, you can disable it and 
reenable it later by following a sequence of steps, which ensures that any buffers currently 
in use are properly closed and that new data is transferred to or from a new buffer. This 
sequence must be followed if you are changing a parameter that cannot be dynamically 
changed. Parameters that are dynamic can be changed immediately. For instance, the 
internal baud rate generators allow on-the-fly changes, but the DPLL-related bits in the 
GSMR_L do not. 


“Oo Note: Modifying parameter RAM does not require that you fully disable the serial 

| communication controller. Refer to the parameter RAM description for details on 
when parameter RAM values can be modified. If you prefer to disable the USB, 
SCC2, SMCs, SPI, and the I?C, use the CPCR to reset the entire communication 
processor module with a single command. 


16.9.14.1 DISABLING THE ENTIRE SCC2 TRANSMITTER. The SCC2 transmitter can 
be fully disabled or enabled by following these steps: 


1. 


Issue the STOP TRANSMIT command to the CPCR if the serial communication 


controller is currently transmitting data. It should stop smoothly. If the serial 


communication controller is not transmitting, then you do not need the STOP 
TRANSMIT command. Furthermore, if you overwrite the TBPTR or execute the INIT 
TX PARAMETERS command, the STOP TRANSMIT command is not required. 


. Clear the ENT bit in the GSMR_L. The SCC2 transmitter is now disabled and put in a 


reset state. 


. Make modifications to the SCC2 transmit parameters or to the parameter RAM. If you 


want to switch protocols or restore the SCC2 transmit parameters to their initial state, 
issue the INIT TX PARAMETERS command to the CPCR. 


. Issue the RESTART TRANSMIT command to the CPCR. This command is required if 


the INIT TX PARAMETERS command was not issued in step 3. 


. Set the ENT bit in the GSMR_L. Transmission begins using the TX buffer descriptor 


that the TBPTR points to as soon as the R bit is set in the TX buffer descriptor. 


16.9.14.2 DISABLING PART OF THE SCC2 TRANSMITTER. To reinitialize the SCC2 
transmitter to the state it was in after reset, follow this short sequence of steps: 


1. 
2: 


3. 


Clear the ENT bit in the GSMR_L. 
Issue the INIT TX PARAMETERS command and make any additional modifications. 
Set the ENT bit in the GSMR_L. 
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16.9.14.3 DISABLING THE ENTIRE SCC2 RECEIVER. The SCC2 receiver can be fully 
disabled or enabled by following these steps: | 


1. Clear the ENR bit in the GSMR_L. The SCC2 receiver is now disabled and put in a 


reset state. 


2. Make modifications to the SCC2 receive parameters or to the parameter RAM. If you 
want to switch protocols or restore the SCC2 receive parameters to their initial state, 
issue the INIT RX PARAMETERS command. 


3. Issue the ENTER HUNT MODE command in the CPCR. This command is required if 
the INIT RX PARAMETERS command was not issued in step 2. 


4. Set the ENR bit in the GSMR_L. Reception begins using the RX buffer descriptor that — 
the RBPTR points to if the E bit is set in the TX buffer descriptor. 


16.9.14.4 DISABLING PART OF THE SCC2 RECEIVER. To reinitialize the SCC2 
receiver to the state it was in after reset, follow this short sequence of steps: 


1. Clear the ENR bit in the GSMR_L. 


2. Issue the INIT RX PARAMETERS command in the CPCR and make any additional 
modifications. 


3. Set the ENR bit in the GSMR_L. 


16.9.14.5 SWITCHING PROTOCOLS. Sometimes you may want to switch the protocol 
that the serial communication controller is executing without resetting the board. You can do 
this by using one command and the following sequence of steps: 


1. Clear the ENT and ENR bits in the GSMR_L. 


2. Issue the INIT TX AND RX PARAMS command in the CPCR. This command 
initializes both the transmit and receive parameters. Any additional modifications can 
be made in the GSMR_L. | 


3. Set the ENT and ENR bits in the GSMR_L. The serial communication controller is 
enabled with the new protocol. | | 


Tip: . You can save power by clearing the ENT and ENR bits of the serial 
communication controller. 
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16.9.15 The SCC2 in UART Mode 


Many applications need a simple method of sending low-speed data between pieces of 
equipment. The universal asynchronous receiver transmitter (UART) protocol is the de-facto 
standard for such communication. The term asynchronous is used because it is not 
necessary to send clocking information along with the data being sent. UART links are 
character-oriented. Asynchronous links are used to connect terminals and other computer 
equipment together. Even in applications where synchronous communication is required, 
the UART is often used for a local debugging port to run board debugger software. The 
character format of the UART protocol is illustrated in Figure 16-72. 


5, 6; 7, OR 8 DATA BITS WITH THE 


LEAST-SIGNIFICANT BIT FIRST 
: | OPTIONAL | 










START Japp} PAR | 946702 
UARTTXD2 1" pry - STOP BITS 
UART TCLK 
8 ¥, 16 ¥, OR 32 ¥ 
(CLOCK NOT TO SCALE). 


Figure 16-72. UART Character Format 


Since the transmitter and receiver operate asynchronously, there is no need to connect the 
transmit and receive clocks. Instead, the receiver oversamples the incoming datastream 
(usually by a factor of 16) and uses some of these samples to determine the bit value. 
Traditionally, the middle three samples of the 16 samples are used. Two UARTs can 
communicate using a system like this if parameters, such as the parity scheme and 
character length, are the same for both the transmitter and receiver. 


When data is not transmitted in the UART protocol, a continuous stream of ones is 
transmitted called the idle condition. Since the start bit is always a zero, the receiver can 
detect when real data is once again present on the line. UART specifies an all-zeros 
character called a break, which is used to abort a character transfer sequence. 


Many different protocols have been defined using asynchronous characters, but the most 
popular of these is the RS-232 standard, which specifies baud rates, handshaking protocols, 
and mechanical/electrical details. Another popular standard using the same character 
format is RS-485, which defines a balanced line system allowing longer cables than RS-232 
links. Synchronous protocols are sometimes defined to run over asynchronous links. Other 
protocols like Profibus extend the UART protocol.to include LAN-oriented features such as 
token passing. | 
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All the standards provide handshaking signals, but some systems require just three physical 
lines—transmit data, receive data, and ground. Many proprietary standards have been built 
around the asynchronous character frame and some even implement a multidrop : 
configuration. In multidrop systems, more than two stations can be present on a network, 
each one with a specific address. Frames made up of many characters can be broadcast 
with the first character acting as a destination address. To accommodate this, the UART 


_ frame is extended one bit to distinguish between an address character and the normal data 


characters. Additionally, a synchronous form of the UART protocol exists where start and 
stop bits are still present, but because a clock is provided with each bit the oversampling 
technique is not required. This mode is called isochronous operation or synchronous UART. 


By appropriately setting the GSMR_L, the SCC2 channel can be configured to function in 
UART mode, which provides standard serial 1/O using asynchronous character-oriented 
(start-stop) protocols with RS-232 C-type lines. The SCC2 in UART mode, also called the 
SCC2 UART controller, can be used to communicate with any existing RS-232 type of 
device and to provide a port for serial communication to other microprocessors and 
terminals (either locally or via modems). It includes facilities for communication using 
standard asynchronous bit rates and protocols. The SCC2 in UART mode supports a 
multidrop mode for master/slave operation with wake-up capability on both the idle signal 


_ and address bit. This mode also supports a synchronous mode of operation where a clock 


must be provided with each bit received. It transmits data from memory (either internal or 
external) to the TXD2 signal and receives data from the RXD2 signal into memory. In 
synchronous UART mode, the clock must also be supplied and it can be generated internally 
or externally. Modem lines are supported via the port B and C pins. The SCC2 in UART 
mode consists of separate transmit an receive sections whose operations are 
asynchronous with the core. 


16.9.15.1 FEATURES 
The following ist summarizes the main features of the SCC2 in UART mode: 


¢ Flexible message- -oriented data structure 

¢ Implements synchronous and ee: UART 
e Multidrop operation 

° Receiver wake-up on idle line or address mode 

e Eight control character comparisons 

e Two address comparisons 


ine Maintenance of four 16-bit error counters 


¢ Received break character length indication 
e Programmable data length (5-8 bits) 
_ ¢ Programmable 1 to 2 stop bits in transmission 
° Capable of reception without a stop bit © 
e Programmable fractional stop bit length 
e Even, odd, force, or no parity generation © 
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e Even, odd, force, or no parity check 

e Frame error, noise error, break, and idle detection 
e Transmit preamble and break sequences 

¢ Freeze transmission option with low-latency stop 


16.9.15.2 NORMAL ASYNCHRONOUS MODE. In normal asynchronous mode, the 

receive shift register receives the incoming data on the RXD2 pin. The control bits in the 

PSMR-—-SCC2 UART register define the length and format of the UART character and each 

bit is received in the following order: oe 
Start bit 

5-8 data bits (LSB first) 
Address/data bit (optional) 
Parity bit (optional) 

Stop bits 


oh ge ee I 


The receiver uses a clock 8x, 16x, or 32x faster than the baud rate and samples each bit of 
the incoming data three times around its center. The value of the bit is determined by the 
majority of those samples and if they do not all agree, a noise indication counter is 
incremented. When a complete byte has been clocked in, the contents of the shift register 
are transferred to a UART receive data buffer. If there is an error in this character, the 
appropriate error bits are set by the communication processor module. | 


The SCC2 UART controller can receive fractional stop bits. The next character’s start bit can 
begin any time after the three middle samples are taken. The UART transmit shift register 
transmits the outgoing data on the TXD2 pin. Data is then clocked synchronously with the 
transmit clock, which may have either an internal or external source. The bit transmission 
order is LSB first, but only the data portion of the UART frame is actually stored in the data 
buffers. The start and stop bits are always generated and stripped by the SCC2 UART 
controller. The parity bit can also be generated in transmission and checked during 
reception and although it is not stored in the data buffer, its value can be inferred from the 
reporting mechanism of the data buffer. Similarly, the optional address bit is not stored in 
the transmit or receive data buffer, but is implied from the buffer descriptor itself. Parity is 
generated and checked for the address bit. The RFW bit of the GSMR_H must be set for an 
8-bit receive FIFO. 


16.9.15.3 SYNCHRONOUS MODE. In synchronous nice: the SCC2 UART controller 
uses a 1x data clock for timing. The receive shift register receives the incoming data on the 
RXD2 pin synchronously to the clock. The length and format of the serial word in bits are 
defined by the control bits in the PSMR-SCC2 UART register in the same way they were in 
asynchronous mode. When a complete byte has been clocked in, the contents of the shift 
register are transferred to a UART receive data buffer. If there is an error in this character, 
then the appropriate error bits are set by the communication processor module. 
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The UART transmit shift register transmits the outgoing data on the TXD2 pin. Data is then 
clocked synchronously with the transmit clock, which can have an internal or external 
source. The RFW bit in the GSMR_H must be set for an 8-bit receive FIFO. | 


16.9.15.4 SCC2 UART PARAMETER RAM MEMORY MAP. When configured to operate 


in UART mode, the serial communication controller overlays the structure used in 
Table 16-24 with the UART parameters described in Table 16-26. 


Table 16-26. SCC2 UART Parameter RAM Memory Map 


SCC2 Base + 30 RES Word 











DESCRIPTION 


































SCC2 Base + 34 


SCC2 Base + 64 





NOTE: You are only responsible for initializing the items in bold. 
SCC2 base = (IMMR & OxFFFFOOO0) + Ox3D00. 
All references to registers in the parameter RAM table are actually implemented in the dual-port 
RAM area as a memory-based register. 
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e MAX_!IDL—Once a character is received, the SCC2 UART controller begins counting 
any idle characters that are received. If a MAX_IDL number of idle characters is 
received before the next data character, an idle timeout occurs and the buffer is closed. 
This, in turn, can produce an interrupt request to the core to receive the data from the 
buffer. Thus, MAX_IDL provides a convenient way to demarcate frames in UART mode. 
To disable the MAX_IDL feature, simply program it to Ox0000. An idle character is 
calculated the following number of bit times: 1 + data length (5, 6, 7, or 8) + 1 (if parity 
bit is used) + number of stop bits (1 or 2). For example, for 8 data bits, no parity, and 1 
stop bit, the character length is 10 bits. 


e |DLC—The RISC microcontroller uses this value to store the current idle counter value pas 
in the MAX_IDL timeout process. IDLC is a down-counter and you do not need to | “2 
initialize or access it. eee 


e BRKCR—The SCC2 UART controller sends a break character sequence whenever a 
STOP TRANSMIT command is issued to the CPCR. The number of break characters 
sent by the SCC2 UART controller is determined by the value in BRKCR. For 8 data 
bits, no parity, 1 stop bit, and 1 start bit, each break character is 10 bits long and 
consists of all zeros. 


e PAREC, FRMEC, NOSEC, and BRKEC—You must initialize these 16-bit (modulo-2'°) 
counters. When the following conditions occur, they are incremented by the RISC 
microcontroller. 

PAREC counts received parity errors. 

FRMEC counts received characters with framing errors. 

NOSEC counts received characters with noise errors. 


BRKEC counts the number of break conditions that occur on the RX pin. Notice that 
one break condition can last for hundreds of bit times, yet this counter is 
incremented only once during that period. : 


Oooo 


e BRKLN—This value is used to store the length of the last break character that is 
received and is as long as the break. For example, if the receive pin is low for 20 bit 
times, BRKLN shows the value 0x0010. BRKLN is accurate to within one character unit 
of bits. For 8 data bits, no parity, 1 stop bit, and 1 Start bit, BRKLN is accurate to within 
10 bits. 


e UADDR1, UADDR2—In multidrop mode, the SCC2 UART controller provides 
automatic address recognition for two addresses. In this case, you program the lower 
order bytes of VADDR1 and UADDR2 with the two preferred addresses. 


¢ TOSEQ—This value is used to transmit out-of-sequence characters in the transmit 
stream. Using this field, the preferred characters can be inserted into the transmit FIFO 
without affecting any transmit buffer that might currently be in progress. 


¢ CHARACTER1 to CHARACTER 8—These characters define the receive control 
characters on which interrupts can be generated. 


¢ RCCM—This value is used to mask the comparison of the CHARACTER1 to 
CHARACTER 8 parameters so that classes of control characters can be defined. A one 
enables the bit comparison and a zero masks it. 
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¢ RCCRP—This value is used to hold the value of any cone character that is.not written 
to the data buffer. 


¢ RLBC—This entry is used in synchronous UART when the RZS bit is set in the 
PSMR-UART and contains the actual pattern of the last break character. By counting 
the zeros in this entry, the core can measure the break length to a bit resolution. You 
read RLBC by counting the number of zeros written, starting at bit 15 continuing to the 
point where the first one was written. Therefore, RLBC = 001xXxxxxxxxxxxxx (binary) 
indicates two zeros and RLBC = 1xxxxxxXxxxxxxxxx (binary) indicates no zeros. 


16.9.15.5 PROGRAMMING THE SCC2 IN UART MODE. The SCC2 UART controller 
uses the same data structure as the other modes and supports multibuffer or multidrop 
operation. You can program the SCC2 UART controller to reject messages that are not 
destined for a programmable address (multidrop mode). You can also program the SCC2 
UART controller to accept or reject control characters. If a control character is rejected, an 
interrupt can be generated. The receive character can be accepted using a receive 
character mask value. 


The SCC2 UART controller enables you to transmit break and preamble sequences. 
Overrun, parity, noise, and framing errors are reported via the buffer descriptor table and/or 
error counters. An indication of the signal line status is reported in the status register anda 
maskable interrupt is generated when the status changes. In its simplest form, the SCC2 
UART controller functions in a character-oriented environment, in which each character is 
transmitted with the stop bits and parity and received into separate 1-byte buffers. A 
maskable interrupt is generated when a buffer is received. 


Using linked buffers, many applications try to take advantage of the message-oriented 
capabilities that the serial communication controller supports in UART mode. Data is 
handled in a message-oriented environment which means that you can work on entire 
messages rather than operating on a character-by-character basis. Also, a message can 
span several linked buffers. For example, before handling the input data, a terminal driver 
may want to wait until you type an end- of-line character rather than be interrupted when a 


character | is received. 


As enolner example, when transmitting ASCII files, the data can be nanciaied as 
messages ending on the end-of-line character. Each message could be both transmitted 
and received as a linked list of buffers without any intervention from the core, which makes 
it easy to program and saves processor overhead. Before reception you can define up to 
eight control characters and each control character can be configured to designate the end 
of a message or generate a maskable interrupt without being stored in the data buffer. The 


latter option is useful when flow control characters such as XON or XOFF need to alert the 


core but do not belong to the received message. 
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16.9.15.6 SCC2 UART COMMANDS. You can program the CPM command register 
(CPCR) with the following commands to transmit data. 


e STOP TRANSMIT—Atter a hardware or software reset and a channel is enabled in the 
PSMR-SCC2 UART register, the channel is in transmit enable mode and starts polling 
the first buffer descriptor in the table every eight transmit clocks. This command 
disables the transmission of characters on the transmit channel and if it is received by 
the SCC2 UART controller while a message is transmitting, the message is aborted. 
The SCC2 UART controller finishes transmitting data that is already transferred to its 
FIFO and then stops. The TBPTR is not incremented, as shown in eee 
Section 16.9.7 SCC2 Parameter RAM Memory Map. The UART transmitter transmits fi 
a programmable number of break sequences and starts transmitting idles. The number 
of break sequences (which can be zero) should be written to the BRKCR before this 
command is given to the SCC2 UART controller. 


GRACEFUL STOP TRANSMIT— This command is used to stop transmitting smoothly, 
rather than abruptly. It is similar to the way the STOP TRANSMIT command finishes. It 
stops after the current buffer has completed transmission or immediately if there is no 
buffer being transmitted. The GRA bit in the SCCE—UART register is set once this 
transmission stops. Then the UART transmit parameters, including the buffer 

descriptors, can be modified. The TBPTR points to the next TX buffer descriptor in the 
table. Transmission begins once the R bit of the next buffer descriptor is set and the 
RESTART TRANSMIT command is issued. 


RESTART TRANSMIT—This command enables characters to be transmitted on the 
transmit channel. The SCC2 UART controller expects this command after it disables 
the channel in its PSMR-—SCC2 UART register, after a STOP TRANSMIT command, 
aftera GRACEFUL STOP TRANSMIT command, or after a transmitter error. The 
SCC2 in UART mode resumes transmission from the cuent TBPTR I inthe channel S 
TX buffer descriptor table. 





INIT TX PARAMETERS—This command initializes all transmit parainclesl in the serial 
channel’s parameter RAM to their reset state and should only be issued when the 
transmitter is disabled. Notice that the INIT TX AND RX PARAMS command can be 
used to reset both the transmit and receive parameters. 


You can program the CPCR with the following commands to receive data. 


e ENTER HUNT MODE—Arfter the hardware or software is reset and a channel is. 
enabled in the PSMR-—SCC2 UART register (described in Section 16.9.15.15 SCC2 
UART Mode Register), the channel is in receive enable mode and uses the first buffer 
descriptor in the table. This command forces the SCC2 UART controller to close the 
current RX buffer descriptor if it is being used and enter hunt mode. The SCC2 UART 
controller continues receiving the next buffer descriptor if a message is in progress. In 
the multidrop hunt mode, the SCC2 UART controller continually scans the input 
datastream for the address character. When it is not in multidrop mode, it waits for the 
idle sequence (one character of idle) and does not lose any data that was in the receive 
FIFO when this command was executed. | 
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¢ CLOSE RX BD—This command forces the serial communication controller to close the 
RX buffer descriptor if it is currently being used and it uses the next buffer descriptor for 
any subsequently received data. If the serial communication controller is not in ine 
pigtes>: of receiving data, no action is 3 taken. 


Note: The CLOSE RX BD command in the SCC2 UART controller functions the same 
as the ENTER HUNT MODE command, except for one difference. CLOSE RX 
_ BD does not need an idle character to be present on the line before it continues 

— receiving. 


¢ INITRX PARAMETERS —This command initializes all receive parameters in this serial 
channel’s parameter RAM to their reset state and should only be issued when the 
receiver is disabled. Notice that the INIT TX AND RX PARAMS command can be used 
to reset the receive and transmit parameters. 


~16.9.15.7 RECOGNIZING ADDRESSES IN SCC2 UART MODE. In multidrop systems, 


more than two stations can be present on a network and each one can have a specific 
address. Figure 16-73 illustrates two examples of this configuration. Frames made up of 
many characters can be broadcast as long as the first character is the destination address. 
To achieve this, the UART frame is extended by one bit to distinguish between an address 
character and the data characters. The SCC2 UART controller can be configured to pees 
ina multidrop environment that supports the tollewind two modes: 


° Automatic Multidrop Mode—The SCC2 UART controller automatically checks the 
incoming address character and accepts the data unOwng it, but enn if the address 
matches one of two preset values. 


¢ Manual Multidrop Mode—The SCC2 UART eontroiler receives all characters. An 
address character is always written to a new buffer and it can be followed by data 
-characters. 


The SCC2 UART controller has two 16-bit address registers that support address 
recognition—UADDR1 and UADDR2. The upper 8 bits of these registers should be written 
with zero because only the lower 8 bits are used. In automatic mode, the incoming address 
is checked against VADDR1 and UADDR2 and when a match is made, the AM bit in the 
buffer descriptor is set to indicate the matched address character and the data vowing it 


is written to the data buffers. 


7 i _ Note: For characters less than 8 bits, the MSBs should be Zero. . 
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Figure 16-73. Two UART Multidrop Mode Configuration Examples 


16.9.15.8 SCC2 UART CONTROL CHARACTERS. The SCC2 UART controller can 
recognize special control characters that can be used in a message-oriented environment. 
You can define a maximum of eight control characters in the control characters table. Each 
character can either be written to the receive buffer or rejected. If it is rejected, the character 
is written to the received control character register in internal RAM and a maskable interrupt 
is generated. This method is used to let you know that the control characters (XON or XOFF) 
that are not part of the received messages have arrived. The SCC2 UART controller uses a 
table of 16-bit entries to support control character recognition and each entry consists of the 
control character, a valid bit, and a reject character bit. 


‘ 
| CHARACTER1 
| CHARACTER2 
CHARACTERS 
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E—End of Table 
In tables with eight control characters, this bit is always zero. 


O= This entry is valid. The lower 8 bits are checked against the incoming character. 
1 = This entry is invalid and must be the last entry in the control characters table. 


R—Reject Character 


O= The character is not rejected, but is watton into the receive buffer. The buffer is 
then closed and a new receive buffer is used if there is more data in the message. 
A maskable interrupt is generated. 

1 = If this character is recognized, it is not written to the receive buffer. Instead, it is 
written to the RCCRP register and a maskable interrupt is generated. The current 
buffer is not closed when a control character is received with the R bit set. 


CHARACTER1—CHARACTER8—Control Character Values 1-8 


These fields define control characters that will be compared to the incoming character. For 
characters smaller than 8 bits, the most-significant bit should be zero. 


RCCM—Received Control Character Mask 


This value is used to mask the comparison of the CHARACTER1—CHARACTER8 fields. 
The lower 8 bits of the RCCM correspond to the lower 8 bits of 


CHARACTER1—CHARACTERS and are decoded as follows: 


O= Mask this bit when the incoming character and CHARACTER1—CHARACTER8 
fields are compared. 
1 = The address comparison on this bit proceeds normally and no masking occurs. 


Note: Bits 0 and 1 of RCCM must be set or erratic operation will occur during the control 
character recognition process. — 





RCCRP—Received Control Character Register 


When a control character match is made and the R bit is set, the SCC2 UART controller 
writes the control character into the RCCRP and generates a maskable interrupt. The core 
must process the interrupt and read the RCCRP before a second control character arrives. 
If this does not occur, the SCC2 UART controller overwrites the first control character. 
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16.9.15.9 WAKE-UP TIMER. By issuing the ENTER HUNT MODE command, you can 
temporarily disable the UART receiver and make it inactive until an idle or address character 
is recognized, depending on how the UM field is set in the PSMR-—SCC2 UART register. See 
Section 16.9.15.15 SCC2 UART Mode Register for more information. 


If the SCC2 UART controller is still in the process of receiving a message that you have 
already decided to discard, you can abort its reception by issuing the ENTER HUNT MODE 
command. When the message is finished, the UART receiver is reenabled by finding the idle 
line or the address bit of the next message, depending on how the UM field is set. When the 
receiver is in sleep mode and receives a break sequence, it increments the BRKEC counter 
and generates an interrupt if the BRKE or BRKS bits are enabled in the SCCM—UART 
register. Refer Section 16.9.15.16 SCC2 UART Receive Buffer Descriptors for more 
information about the type of receive interrupt that is registered. 


16.9.15.10 BREAK SUPPORT. The SCC2 UART controller provides flexible break support 
to the receiver. Transmitting out-of-sequence characters is also supported by the SCC2 
UART controller and is normally used for the transmission of flow control characters like 
XON or XOFF. This procedure is performed using the TOSEQ entry in the SCC2 UART 
parameter RAM. 


The SCC2 UART controller polls the TOSEQ character whenever the transmitter is enabled 
for UART operation, including during a UART freeze operation, UART buffer transmission, 
and when no buffer is ready for transmission. TOSEQ is transmitted at a higher priority than 
the other characters in the transmit buffer, but does not preempt characters already in the 
transmit FIFO. This means that the XON or XOFF character may not be transmitted for eight 
or four character times. To reduce this latency, the TFL bit in the GSMR_H should be set to 
decrease the FIFO size to one character prior to enabling the SCC2 transmitter. 


TOSEQ 







CHARSEND 
SCC2 BASE + 0x4E 


Bits O—1 and 5-6—Reserved 
These bits are reserved and should be set to 0. 





REA—Ready | 

This bit is set by the core when the character is ready for transmission and remains 1 while 
the character is being transmitted. The communication processor module clears this bit after 
transmission. _ 
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I—Interrupt 


If this bit is set, the character in the CHARSEND field is transmitted. The TX bit is then set 
in the SCCE—-UART register and the core may be interrupted. 


CT—Clear-to-Send Lost 


This status bit indicates that the CTS signal was negated when this character was 
transmitted. If negation occurs, the CT bit in the UART transmit buffer descriptor is also set. 
The DIAG field in the GSMR_L controls whether the CTS signal is monitored by the serial 
communication controller. 


wr Note: If the CTS signal is negated during transmission and the communication 

| processor module transmits this character in the middle of a buffer transmission, 
the CTS signal could actually have been negated either during this character’s 
transmission or during a buffer character's transmission. In either case, the 
communication processor module sets the CT bit both here and | in the TX puller 
descriptor status word. 


A—Address 


O= In multidrop mode, the character being sent is a data character. 
1 = In multidrop mode, the character being sent is address character. 


CHARSEND—Character Send 


This field contains the character to be transmitted. Any 5-, 6-, 7-, or 8-bit character value can 
be transmitted in accordance with the SCC2 UART configuration. The character is in the 
least-significant bits of CHARSEND. This value can be modified only while the REA bit is 
cleared. | 


- 16.9.15.11 SENDING A BREAK. A break is an all-zeros character without a stop bit and 


you can send it by issuing the STOP TRANSMIT command. The SCC2 UART controller 
finishes transmitting any outstanding data, sends a programmable number of break 
characters according to the BRKCR, and then reverts to idle or sends data if the RESTART 
TRANSMIT command was given before completion. When the break code is complete, the 
transmitter sends at least one high bit before transmitting anymore data to guarantee a valid 
start bit will be recognized. The break characters do not preempt characters already in the 
transmit FIFO, which means that the break character may not be transmitted for eight or four 
character times. To reduce this latency, set the TFL bit in the GSMR_H so that the FIFO size 
will be reduced to one character before the SCC2 transmitter is enabled. 


16.9.15.12 SENDING A PREAMBLE. A preamble sequence is a convenient way for you to 
ensure that a line is idle before you start a new message. The preamble sequence length is 
constructed of consecutive ones of one character length. If the P bit in the UART transmit 
buffer descriptor is set, the serial communication controller sends a preamble sequence 
before transmitting that data buffer. For example, for 8 data bits, no parity, 1 stop bit, and 1 
start bit, a preamble of 10 ones is sent before the first character in the buffer. 
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16.9.15.13 FRACTIONAL STOP BITS. You can program the asynchronous UART 
transmitter to transmit fractional stop bits. Using four bits in the SCC2 UART data 
synchronization register (DSR-SCC2 UART), you can program the length of the last stop 
bit to be transmitted. These bits can be modified at any time and if two stop bits are 
transmitted, only the second one is affected. Idle characters are always transmitted as 
full-length characters. 


DSR-SCC2 UART 





(IMMR & OxFFFO000) + 0xA2E 


NOTE: X= “Don’t Care”. 


FSB—Fractional Stop Bit 


The value you programmed into the TDCR determines which set of values to use here. 
When the serial communication controller is in UART mode with 32x oversampling, the FSB 
field is decoded as follows in the DSR-SCC2 UART: 


—1111= Last transmitted stop bit 32/32. Default value after reset. 
1110 = Last transmitted stop bit 31/32. 
1101 = Last transmitted stop bit 30/32. 
1100 = Last transmitted stop bit 29/32. 
1011 = Last transmitted stop bit 28/32. 
1010 = Last transmitted stop bit 27/32. 
1001 = Last transmitted stop bit 26/32. 
1000 = Last transmitted stop bit 25/32. 
0111 = Last transmitted stop bit 24/32. — 
0110 = Last transmitted stop bit 23/32. 
0101 = Last transmitted stop bit 22/32. 
0100 = Last transmitted stop bit 21/82. 
0011 = Last transmitted stop bit 20/32. 

_ 0010 = Last transmitted stop bit 19/32. 
0001 = Last transmitted stop bit 18/32. 
0000 = Last transmitted stop bit 17/82. 
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For 16x oversampling, the FSB field is decoded as follows: 


111= = Last transmitted stop bit 16/16. Default value after reset. 
1110 = Last transmitted stop bit 15/16. ” 7 
1101 = Last transmitted stop bit 14/16. 
- 1100 = Last transmitted stop bit 13/16. 
1011 = Last transmitted stop bit 12/16. 
1010 = Last transmitted stop bit 11/16. 
1001 = Last transmitted stop bit 10/16. 
1000 = Last transmitted stop bit 9/16. 
Oxxx = Invalid. Do not use. 





For 8x oversampling, the FSB tieid is decoded as follows: 


1111 = Last transmitted stop bit 8/8. Default value after reset. 
1110 = Last transmitted stop bit 7/8. 

1101 = Last transmitted stop bit 6/8. 

1100 = Last transmitted stop bit 5/8. 

10xx = Invalid. Do not use. 

01xx = Invalid. Do not use. 

O00xx = Invalid. Do not use. 


The SCC2 UART receiver can always receive fractional stop bits. The next character’s start 
bit can begin at any time after the three middle samples of the stop bit have been taken. 


16.9.15.14 SCC2 UART CONTROLLER ERRORS. The SCC2 UART controller reports 
character reception and transmission error conditions via the channel buffer descriptors, the 
error counters, and the SCCE—-UART register. The modem interface lines can be monitored 
by the port B and C pins. The following transmission error can be detected by the SCC2 
UART controller. 


¢ CTS Lost During Character Transmission —When this error occurs, the channel stops 
transmission after finishing transmission of the current character from the buffer. The 
channel then sets the CT bit in the TX buffer descriptor and generates the TX interrupt 
if it is not masked. The channel resumes transmission after the RESTART TRANSMIT 
command is issued and the CTS pin is asserted. 


Note: Using CTS signal, the SCC2 UART controller also offers an asynchronous flow 
control option that does not generate an error. Refer to the FLC bit of the 
PSMR-SCC2 UART register description in Section 16.9.15.15 SCC2 UART 
Mode Register for information about flow control. 
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The following reception errors can be detected by the SCC2 UART controller: 


Overrun Error—This error occurs when data is moved from the receiver FIFO to the 
data buffer after the first byte is received. If a receiver FIFO overrun occurs, the channel 
writes the received character into the internal FIFO and over the previously received 
character. The channel then writes the received character to the buffer, closes it, sets 
the OV bit in the RX buffer descriptor, and generates the RX interrupt if it is enabled. In 
automatic multidrop mode, the receiver enters hunt mode immediately. 


CD Lost During Character Reception Error—lf this error occurs and the channel is using 
this pin to automatically control reception, the channel terminates character reception, 
closes the buffer, sets the CD bit in the RX buffer descriptor, and generates the RX 
interrupt if it is enabled. This error has the highest priority. The last character in the 
buffer is lost and other errors are not checked. In automatic aoe mode, the 
receiver enters the hunt mode immediately. 


Parity Error—When a parity error occurs, the channel writes the received character to 
the buffer, closes the buffer, sets the PR bit in the RX buffer descriptor, and generates 
the RX interrupt if it is enabled. The channel also increments the PAREC counter. In 
automatic multidrop mode, the receiver enters hunt mode immediately. 


Noise Error—The SCC2 UART controller detects a noise error when three different 
samples are taken on every bit. When this error occurs, the channel writes the received 
character to the buffer, proceeds normally, but increments the noise error. 


Note: A noise error will not occur when the SCC2 UART controller is in synchronous 
mode. | | 





Idle Sequence Receive Error—When the SCC2 UART controller receiver receives all 
ones in the receive buffer (idle sequence), the channel counts the number of 
consecutive idle characters that were received. If the count reaches the value 
programmed into MAX_IDL, the buffer is closed and an RX interrupt is generated. If no 
receive buffer is open, this event does not generate an interrupt or any status 
information. The internal idle counter (IDLC) is reset every time a character is received. 


Note: To disable the idle sequence function, set the MAX_IDL value to zero. 
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e Framing Error—The SCC2 UART controller gets this error when it receives a character 
with no stop bit. All framing errors are reported by the SCC2 UART controller, 

_ regardless of its mode. When this error occurs, the channel writes the received 
character to the buffer, closes it, sets the FR bit in the RX buffer descriptor, and 
generates the RX interrupt if it is enabled. The channel also increments FRMEC. When 
this error occurs, parity is not checked for this character. In automatic multidrop mode, 
the receiver immediately enters hunt mode. If the RZS and SYN bits are set in the 
PSMR-SCC2 UART register when the SCC2 UART controller is in synchronous mode, 
the receiver reports all framing errors, but continues reception if the unexpected zero is 

_ really the start bit of the next character. If RZS is set, your software may not consider a 

_ reported SCC2 UART framing error as a true framing error, unless two or more framing 

errors occur within a short period of time. , 





e Break Sequence Error—The SCC2 UART controller. provides flexible break support to 
the receiver. When the first break sequence is received, the SCC2 UART controller 
increments the BRKEC and issues the break start event in the SCCE—UART register, 
which can generate an interrupt if it is enabled. The SCC2 UART. controller then 
measures the break length and, when the break sequence is complete, writes the 
length to the BRKLN register. After the first one is received, the SCC2 UART controller 
also issues the break end event in the SCCE—-UART register, which can generate an 
interrupt if it is enabled. If the SCC2 UART controller was in the process of receiving 
characters when the break was received, it also closes the receive buffer, sets the BR 
bit in the RX buffer descriptor, and writes the RX bit in the SCCE—-UART register, which 
can generate an interrupt if it is enabled. If the RZS bit is set in the PSMR-—SCC2 UART 
register when the SCC2 UART controller is in synchronous mode, then a break 

- sequence is detected after only two successive break characters are received. 
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16.9.15.15 SCC2 UART MODE REGISTER.When the SCC2 is in UART mode, the 16-bit, 
memory-mapped, read/write protocol-specific mode register is referred to as the SCC2 
UART mode register (PSMR-—SCC2 UART). Since each protocol has specific requirements, 
the PSMR bits are different for each implementation. Many of the bits can be modified 
on-the-fly while the receiver and transmitter are enabled. 


PSMR-SCC2 UART 





(IMMR & OxFFFFO000) + 0xA28 


FLC—Flow Control 


O = Normal operation. The GSMR_x and port C registers determine the mode of the 
CTS pin. 

1 = Asynchronous flow control. When the CTS pin is negated, the transmitter stops at 
the end of the current character. If CTS is negated past the middle of the current 
character, the next full character can be sent and transmission is stopped. When 
CTS is asserted once more, transmission continues where it left off and no CTS 
lost error is reported. No characters except idles are transmitted while CTS is. 
negated. 


SL—Stop Length 

This bit selects the number of stop bits transmitted by the Scce UART controller. It can be 
modified on-the-fly. The receiver is always enabled for one stop bit unless the SCC2 UART 
controller is in synchronous mode and the RZS bit is set. Fractional stop bits are configured 
in the general DSR, which is described in Section 16.9.4 Data Synchronization Register. 


O= One stop bit. 
1 = Two stop bits. 


CL—Character Length 


This field determines the number of data bits in the character, not including the optional. 
parity or multidrop address bits. When you use a character that is less than 8 bits, the 
most-signifiant bits in memory are written as zeros and they are labeled “don’t care” when 
they are transmitted. This field can be modified on-the-fly. | 


00 = 5 data bits. 
01 = 6 data bits. 
10 = 7 data bits. 
11 = 8 data bits. 
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UM—UART Mode 


This field selects the protocol that i is eee over the ASYNC channel and it can be 
modified on-the-fly. 


00 = Normal UART operation. Multidrop mode is disabled and an idle-line wake-up is 
selected. In the idle-line wake-up mode, the UART receiver is reenabled by 
receiving a character of all ones. 

01 = Manual multidrop mode. In multidrop mode, an additional address/data bit is 

transmitted with each character. The multidrop asynchronous modes are 
compatible with the MC68681 DUART, MC68HC11 SCI, DSP56000 SCI, and 

: Intel 8051 serial interface. The UART receiver is reenabled when the last bit 

ee, received in the character is a one. This means that the received character is an 

address that has to be processed by all inactive processors. The SCC2 UART 
controller receives the address character and writes it to a new buffer. The core 
then compares the written address with its own address and decides whether to 
ignore or process the following characters. 
10 = Reserved. 
11 = Automatic multidrop mode. In this mode, the communication processor module 
automatically checks the address of the incoming address character using the 
~UADDR1-and UADDR2 parameter RAM values and pceeuls or discards the data 
that follows the bce 








FRZ—Freeze Trancniesion 


This bit allows you to stop the UART transmitter and continue transmission from the same 
point at a later time. 


0 = Normal operation. If the SCC2 UART controller was previously frozen, the UART 
resumes transmission from the next character in the same buffer that was frozen. 

41 = The SCC2 UART controller completes transmission of any data already transferred 
to the UART FIFO (the number of characters depends on the TFL bit in the 
GSMR_H) and then freezes. After this bit is reset, transmission proceeds from the 
next character. 


RZS—Receive Zero Stop Bits 


This bit configures the UART receiver to receive data without any stop bits. This 
configuration is useful in V.14 applications where SCC2 UART controller data is supplied 
synchronously and all stop bits of a particular character can be omitted for the purpose of 
cross-network rate adaptation. RZS should only be set if the SYN bit is also set. 


O= The receiver operates normally, but at least one stop bit is required between | 
characters. A framing error is issued when there is a missing stop bit and a break 
status is set if a character with all-zero data bits is received with a zero stop bit. 

1 = The receiver continues if a missing stop bit is detected. If the stop bit is a zero, the 
next bit is considered the first data bit of the next character. A framing error is 
issued if a stop bit is missing, but a break status is only reported after back-to-back 
reception of two break characters without stop bits. 


38 
oe- 
Oz 
TM & 
GZ 
roke) 
2 
33 
US 
=. 

ier 
m 





16-212 MPC823 USER’S MANUAL . MOTOROLA 


Communication Processor Module 


SYN—Synchronous Mode 


O = Normal asynchronous operation. Normally, you program the TENC and RENC 
fields in the GSMR_L to NRZ and select either 8x, 16x, or 32x in the RDCR and 
TDCR fields of the GSMR_L. 16x is the recommended value for most applications. 

1 = Synchronous SCC2 UART controller using 1x clock. Normally, you program the 
TENC and RENC fields in the GSMR_L to NRZ and set the RDCR and TDCR fields 
in the GSMR_L to 1x mode. A 1 bit is transferred with each clock and is 
synchronous to the clock. As with the other modes, the clock can be provided 
internally or externally. This mode is sometimes referred to as isochronous UART 
channel operation. 


DRT—Disable Receiver While Transmitting 
O = Normal operation. 
1 = While the SCC2 UART controller is transmitting data, the receiver is disabled. This 
is useful if the SCC2 UART controller is configured onto a multidrop line and you 
do not want to receive your transmission. 


Note: You should set the preamble bit in the transmit buffer descriptor if you are using 
the MPC823 in multidrop UART mode. 





Bit 10—Reserved 
This bit is reserved and should be set to 0. 


PEN—Parity Enable 
O= No parity. 
1 = Parity is enabled and determined by the parity mode bits. 


RPM—Receiver Parity Mode 


This field selects the type of parity check that the receiver will perform. It can be modified 
on-the-fly. | | 


00 = Odd parity. 

01 = Low parity. Always check for a zero in the parity bit position. 
10 = Even parity. 

11 = High parity. Always check for a 1 in the parity bit position. 


When odd parity is selected, the transmitter counts the number of ones in the data word. If 
the total number of ones is not an odd number, the parity bit is set to 1 and produces an odd 
number. If the. receiver counts an even number of ones, an error in transmission has 
occurred. In the same manner, for even parity, an even number must result from the 
calculation performed at both ends of the line. In high or low parity (also called mark or space 
parity), if the parity bit is not high or low, a parity error is reported. 
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Note: The receive parity errors can be ignored, but not disabled. 





TPM—Transmitter Parity Mode 


This field selects the type of pany that the transmitter performs. It can be modified 
on-the-fly. 


00 = Odd parity. 

01 = Force low parity. Always send a zero in the parity bit ipadiion: 
10 = Even parity. 

11 = Force high parity. Always send a 1 in the parity bit position. 


16.9.15.16 SCC2 UART RECEIVE BUFFER DESCRIPTORS.On a per-buffer basis, the 
communication processor module uses the receive (RX) buffer descriptors to report 
information about the received data. The communication processor module closes the 
current buffer, generates a maskable interrupt, and starts receiving data into the next buffer 
after one of the following events occur: 


e A user-defined control character is received. 
e An error occurs during message processing. 
_ © A full receive buffer is detected. 
e A MAX_IDL number of consecutive idle characters is received. 
e The ENTER HUNT MODE command is issued. 
¢ The CLOSE RX BD command is issued. 


An address character is received in multidrop mode. The address character is written to the 
next buffer for a software comparison. 


Note: The communication processor module sets all the status bits in this buffer © 
| descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 





An example of the RX buffer descriptor process is illustrated in Figure 16-74. 
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TIME HAS FRAMING ERROR! 


Figure 16-74. SCC2 UART Receive Buffer Descriptor Example 
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Communication Processor Module 


RX DATA BUFFER POINTER 





NOTE: You are only responsible for initializing the items in bold. 


E—Empty 

- Q= The data buffer associated with this RX buffer descriptor has been filled with data 
or reception has been aborted because of an error condition. The core is free to 
examine or write to any fields of this RX buffer descriptor. The communication 
processor module does not use this buffer descriptor again as long as the E bit is 
zero. | 

1 = The data buffer associated with this buffer descriptor is empty or is currently 

receiving data. This RX buffer descriptor and its associated receive buffer are 
owned by the communication processor module. Once the E bit is set, the core 
should not write any fields of this RX buffer descriptor. 


Bits 1, 9, and 13—Reserved | 
These bits are reserved and should be set to 0. 


W—Wrap (Final Buffer Descriptor in Table) 


0 = This is not the last buffer descriptor in the RX buffer descriptor table. 
= This is the last buffer descriptor in the RX buffer descriptor table. After this buffer 
has been used, the communication processor module receives incoming data into 
the first buffer descriptor that RBASE points to in the table. The number of RX 
buffer descriptors in this table are programmable and determined only by the W bit 
and overall space constraints of the dual-port RAM. 


I—Interrupt 


O = No interrupt is generated after this buffer is filled. 

1 = The RX bit in the SCCE-UART register is set when this buffer is completely filled 
by the communication processor module, indicating the need for the core to 
process the buffer. The RX bit can cause an interrupt if it is enabled. 


C—Control Character 


0 = This buffer does not contain a control character. | 
1 = This buffer contains a control character. The last byte in the buffer is one of the 
user-defined control characters. 
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A—Address 


O = The buffer only contains data. 

1 = When operating in manual multidrop mode, this bit indicates that the first byte of 
this buffer contains an address byte. The address comparison should be 
implemented in the software. In automatic multidrop mode, this bit indicates that 
the buffer descriptor contains a message that was received immediately after an 
address was recognized in UADDR1 or UADDR2. This address is not written into 
the receive buffer. 


CM—Continuous Mode 


O = Normal operation. 

1 = The E bit is not cleared by the communication processor module after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
overwritten next time the communication processor module accesses this buffer 
descriptor. However, the E bit is cleared if an error occurs during reception, 
regardless of how the CM bit is set. 


|D—Buffer Closed on Reception of Idles 


This bit indicates that the buffer is closed because a programmable number of consecutive 
idle sequences (MAX_IDL) was received. 


AM—Address Match 


This bit is only significant if the address bit is set and the automatic multidrop mode is 
selected in the UM bits. After an address match, this bit defines which address character 
matched the address character that you defined, which enables the SscG2 UART controller 
to receive data. 


0 = The address matched the value in UADDR2. 
1 = The address matched the value in UADDR1. 


BR—Break Received 


This bit indicates that a break sequence has been received at the same time that data is 
being received into this buffer. 


FR—Framing Error 


This bit indicates that a character with a framing error has been received and located in the 
last byte of this buffer. A framing error is a character without a stop bit. A new receive buffer 
is used to receive more data. 


PR—Parity Error 


This bit indicates that a character with a parity error has been received and located in the 
last byte of this buffer. A new receive buffer is used to receive more data. 


OV—Overrun 


This bit indicates that a receiver overrun has eeeuiied while the SCC2 UART controller was 
receiving a message. 
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CD—Carrier Detect Lost 


This bit indicates that the carrier detect signal has been negated while the SCC2 UART 
controller was recelving a Mice de 


DATA LENGTH 
This field represents the number of octets that the communication processor module writes 


into this buffer descriptor’s data buffer. It is written by the communication processor module 
once the buffer descriptor is closed. 


: Note: The actual amount of memory allocated for this buffer should be at least as much 
FT as the contents of the MRBLR. 


RX DATA BUFFER POINTER 


This field always points to the first location of the associated data buffer and they can be 
even or odd. The buffer can reside in internal or external meMialy: 


16.9.15.17 SCC2 UART TRANSMIT BUFFER DESCRIPTOR. The communication 
processor module receives data transmitted on an SCC2 channel by arranging it in buffers 
referenced by the channel's transmit (TX) buffer descriptor table. Using the buffer 
descriptors, the communication processor module confirms transmission and indicates error 
conditions so that the processor knows that the buffers have been serviced. 


DG 


ra | es 


TX DATA BUFFER POINTER 





NOTE: You are only responsible for initializing the items in bold. 


“OT Note: The communication processor module sets all the status bits in this buffer 
: descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. | 
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R—Ready 7 

0 = The data buffer associated with this buffer descriptor is not ready to be transmitted. 
You are free to manipulate this buffer descriptor or its associated data buffer. The 
communication processor module clears this bit after the buffer is transmitted or 
after an error condition is encountered. 

1 = The data buffer, which you must prepare for transmission, has not been 
transmitted yet or is currently being transmitted. You cannot write any fields of this 
buffer descriptor once this bit is set. 


Bits 1 and 9-14—Reserved _ 
These bits are reserved and should be set to 0. \ Ss 





W—Wrap (Final Buffer Descriptor in Table) 

0 = This is not the last buffer descriptor in the TX buffer descriptor table. 

1 = This is the last buffer descriptor in the TX buffer descriptor table. After this buffer 
has been used, the communication processor module will transmit data from the 
first buffer descriptor that TBASE points to in the table. The number of TX buffer 
descriptors in this table are programmable and determined only by the W bit and 
overall space constraints of the dual-port RAM. 


I—Interrupt 
O = No interrupt is generated after this buffer is serviced. 
1 = The TX bit in the SCCE—-UART register is set when this buffer is serviced ae the 
communication processor module, which can cause an interrupt. 


CR—Clear-to-Send Report 


This bit allows you to choose between either no delay between buffers transmitted in SCC2 
UART mode, or a more accurate CTS lost error report and three bits of idle between buffers. 


0 = The buffer following this buffer is transmitted with no delay (assuming it is ready), 
but the CT bit may not be set in the correct TX buffer descriptor or may not be set 
at all in a CTS lost condition. Asynchronous flow control, however, continues to 
function normally. 

1 = Normal CTS lost error reporting and three bits of idle occur between back-to-back 
buffers. 


A—Address , 
This bit is only valid in multidrop mode. Either automatic or anual 


0 = This buffer only contains tie 
= Set by the core, this bit indicates that this buffer contains address characters. All 
of the buffer data is transmitted as address characters. 
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CM—Continuous Mode | 


O = Normal operation. | 

1 = The communication processor module does not clear the R bit after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
retransmitted next time the communication processor module accesses this buffer 
descriptor. However, the R bit is cleared if an error occurs during transmission, 
regardless of how the CM bit is set. 


P—Preamble 


0 = No preamble sequence is sent. 

1 = The SCC2 UART controller sends one character that consists of all ones before it 
sends the data so that the other remote receiver can detect an idle line before the 
data. If this bit is set and the data length of this buffer descriptor is Zero, only a 
preamble is sent. | 


NS—No Stop Bit Transmitted 

O = Normal operation. Stop bits are sent with all characters in this buffer. 

1 = By setting the SYN bit in the PSMR-SCC2 UART register, the data in this buffer is 
sent without stop bits if the Sync mode is selected. If Async is selected, the stop bit 
is transmitted as defined by the FSB field in the general DSR, as described | in 
Section 16.9.4 Data Syne nroneaven Register. 


CT—CTS Lost 


The communication processor module writes this bit after it finishes transmitting the 
associated data buffer. 


0 = The CTS signal remains asserted during transmission. 
1 = The CTS signal is negated during transmission. | 


DATA LENGTH — | | 

This field represents the number of octets that the communication processor module should 
transmit from this buffer descriptor data buffer. It is never modified by the communication 
processor module. Normally, this value should be greater than zero. The data length can be 


equal to zero with the P bit set and only a preamble is sent. The communication processor 


module writes these bits after it finishes transmitting the associated data buffer. 


TX DATA BUFFER POINTER 


This field always points to the first location of the associated data buffer and can be even or 
odd. The buffer can reside in internal or external memory. The communication processor 
module writes these bits after it finishes transmitting the associated data buffer. 
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16.9.15.18 SCC2 UART EVENT REGISTER.When the SCC2 is in UART mode, the 16-bit 
memory-mapped SCC2 event register is referred to as the SCC2 UART event register 
(SCCE-—UART). Since each protocol has specific requirements, the SCCE bits are different 
for each implementation. This register is used to report events recognized by the UART 
channel and to generate interrupts. When an event is recognized, the SCC2 UART 
controller sets the corresponding bit in the UART event register. Interrupts generated by this 
register can be masked in the SCCM-—UART register. An example of interrupts that can be 
generated by the SCC2 UART controller is illustrated in Figure 16-75. 


CHARACTERS 
RECEIVED BY UART 


ee LINE IDLE 


RXD2 LINE IDLE ry | ft tt fob eet BREAK 


CD 


10 CHARACTERS 


UART SCCE 
EVENTS CD IDL RX CCR IDL RX IDL BRKs BRKe IDL CD 


NOTES: 
1. The first RX event assumes receive buffers are 6 bytes each. 
2. The second IDL event occurs after an all-ones character is received. 
3.. The second RX event position is programmable based on the MAX_IDL value. 
4. The BRKs event occurs after the first break character is received. 
5. The CD event must be programmed in the port C parallel I/O, not in SCC2 itself. 


LEGEND: 
A receive control character defined not to be stored in the receive buffer. 





CHARACTERS 
TRANSMITTED BY UART 7 CHARACTERS 


TXD2 LINE IDLE LINE IDLE 





RTS 


CTS 





UART SCCE | La 
EVENTS CTS - | ™ CTS 


NOTES: : 


1. TX event assumes all seven characters were put into a single buffer and CR = 1 in the Tx BD. 
2. The CTS event must be programmed in the port C parallel I/O, not in the SCC itself. 


Figure 16-75. SCC2 UART Interrupt Event Example 
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A bit is cleared by writing a 1 (writing a zero has no effect) and more than one bit can be 
cleared at a time. All unmasked bits must be cleared before the communication processor 
module clears the internal interrupt request. This register | is cleared at reset and can be read 
at any time. : 


SCCE-UART 


oS 
eevee fon ot [ees] [ [ev mea] fon ter | | 


ew Pan an [an Pan aw [ow [aw [ow [aw [aw [aw [a0 [a 


(IMMR & OxFFFF0000) + 0xA30 





Bits 0-2, 5, and 11—Reserved 
These bits are reserved and should be set to O. 


GLR—Glitch on RX 
If set, this bit indicates that the SCC2 has encountered a clock glitch on the receive clock. 


GLR—Glitch on TX 
If set, this bit indicates that the SCC2 has encountered a clock glitch on the transmit clock. 


AB—Auto Baud 


If set, this bit indicates that an auto baud lock has been detected. The core should rewrite 
the baud rate generator with the precise divider value for the preferred baud rate. Refer to 
Section 16.8 The Baud Rate Generators for more details. 


IDL—Idle Sequence Status Changed 


If set, this bit indicates that a change in the serial line’s status has been encountered on the 
UART channel. The real-time status of the line can be read in the SCCS—UART. Idle is 


entered when a character of all ones is received and it is exited when a single zero is 


received. 


GRA—Graceful Stop Complete 


If set, this bit indicates that a graceful stop, which is initiated by the GRACEFUL STOP 
TRANSMIT command, is complete. This bit is set as soon as the transmitter has finished 
with any buffer in progress when the command was issued. It is set immediately if no buffer 
was in progress when the command was issued. 


BRKE—Break End 


lf set, this bit indicates that an end of a break sequence has been found. This indication is 
set no sooner than after an idle bit is received following a break sequence. 
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BRKS—Break Start 


If set, this bit indicates when a break character is received. It is the first break of a break 
sequence. You do not receive multiple BRKS events if a long break sequence is received. 


CCR—Control Character Received 


If set, this bit indicates when a control character is received and stored in the receive control 
character register (RCCRP). | 


BSY—Busy Condition 


If set, this bit indicates that a character has been received and discarded due to a lack of 
buffers. If multidrop mode is selected, the receiver automatically enters hunt mode. 
Otherwise, reception continues as soon as an empty buffer is provided. The latest point that 
an RX buffer descriptor can be changed to empty and still guarantee avoiding the busy 
condition, is the middle of the stop bit of the first character to be stored in that buffer. 


TX—TX Buffer 

If set, this bit indicates that a buffer has been transmitted over the UART channel. If CR = 1 
in the TX buffer descriptor, this bit is set no sooner than when the last stop bit of the last 
character in the buffer is first transmitted. If CR = 0, this bit is set after the last character is 
written to the transmit FIFO. 


RX—RX Buffer 
If set, this bit indicates that a buffer has been received over the UART channel. This event 


occurs no sooner than the middle of the first stop bit of the character that caused the buffer 
to close. 


16.9.15.19 SCC2 UART MASK REGISTER.When the SCC2 is in UART mode, the 16-bit, 
read/write SCC2 mask register is referred to as the SCC2 UART mask register _ 
(SCCM-UART). It has the same bit formats as the SCCE-—UART register. If a bit in this 
register is a 1, the corresponding interrupt in the SCCE—UART register is enabled. If it is 
zero, the corresponding interrupt in the event register is masked. 


SCCM-UART 





(IMMR & OxFFFF0000) + 0xA34 
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16.9.15.20 SCC2 UART STATUS REGISTER.When the SCC2 is in UART mode, the 
8-bit read-only SCC2 status register is referred to as the SCC2 UART status register 
(SCCS—UART). Since each protocol has specific requirements, the SCCS bits are different 
for each implementation. This register allows you to monitor real-time status conditions on 
the RXD2 pin. The real-time status of the CTS and CD pins are part of the port C parallel I/O. 


SCCS-UART 


RESERVED 


] (IMMR & OxFFFF0000) + 0xA37 | 


Bits O-6—Reserved | 
These bits are reserved and should be set to 0. 


|ID—Idle Status 
This bit is set when the RXD2 pin has been a logic one for at adi a full character time. 


O= The pin is not idle. 
1= - The pin is idle. 


16.9.15.21 SCC2 UART PROGRAMMING EXAMPLE.The following initialization 
sequence is for the 9,600 baud, 8 data bits, no parity, and stop bit of an SCC2 in UART mode 
assuming a 25MHz system frequency. BRG1 is used in the example. The SCC2 UART 
controller is configured with the RTS2, CTS2, and CD2 pins active and the CTS2 pinis used 
as an automatic flow control signal. 








1. Configure the port A pins to enable the TXD2 and RXD2 pins. Write PAPAR bits 13 
and 12 with ones and then write the PADIR and PAODR bits 13 and 12 with zeros. 


2. Configure the port C pins to enable RTS2, CTS2, and CD2. Write PCPAR bit 14 with | 
one and bits 9 and 8 with zeros, PCDIR bits 14, 9, and 8 with zeros, and PCSO bits 9 
and 4 with ones. 


3. Configure BRG1, and write BRGC1 with 0x010144. The DIV16 bit is not used and the 
divider is 162 (decimal). The resulting BRG1 clock is 16x the preferred bit rate of the 
SCC2 in UART mode. 


4. Connect the BRG1 clock to the SCC2 using the serial interface. Write the R2CS field 
in the SICR to 000 and the T2CS field in the SICR to 000. 


5. Write 0x0001 to the SDCR to set the SDMA bus arbitration level to 5. 
6. Connect the SCC2 to the NMSI and clear the SC2 bit in the SICR. 
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7. Write to RBASE and TBASE in the SCC2 parameter RAM to point to the RX and TX 
buffer descriptors in the dual-port RAM. Assuming one RX buffer descriptor at the 
beginning of dual-port RAM and one TX buffer descriptor following that RX buffer 
descriptor, write RBASE with 0x2000 and TBASE with 0x2008. 


8. Write 0x0041 to the CPCR to execute the INIT RX AND TX PARAMS command for 
SCC2. 


9. Write 0x15 into the RFCR and 0x15 into the TFCR for normal operation. 


10.Write MRBLR with the maximum number of bytes per receive buffer. For this case, 
assume 16 bytes, so MRBLR = 0x0010. 


11.Write MAX_IDL with 0x0000 in the SCC2 UART parameter RAM to disable the | 
MAX_IDL functionality for this example. 


12.Write 0x0001 to the BRKCR, so that if a STOP TRANSMIT command is issued, one 
break character is sent. 


13. Clear PAREC, FRMEC, NOSEC, and BRKEC in the SCC2 UART parameter RAM. 
14.Clear VADDR1 and UADDR2. They are not used. 

15.Clear TOSEQ. It is not used. 

16.Write CHARACTER1—CHARACTER8 with 0x8000. They are not used. | 

17.Write RCCM with OxCOFF. It is not used. 

18. Initialize the RX buffer descriptor. Assume the RX data buffer is at 0x00001 000 in main 


memory. Write OxBO00 to RX_BD_Status, 0x0000 to RX_BD_Length (optional), and 
0x00001000 to RX_BD_Pointer. 


19. Initialize the TX buffer descriptor. Assume the TX data buffer is at 0x00002000 in main 


memory and contains five 8-bit characters. Write 0xBO00 to TX_BD_Status, 0x0010 
to TX_BD_Length, and 0x00002000 to TX_BD_Pointer. 


20.Write OxFFFF to the SCCE—UART register to clear any previous events. 


21.Write 0x0003 to the SCCM-UART register to enable the transmit and receive 
interrupts. 


22.Write 0x20000000 to the CIMR to allow SCC2 to poner a system interrupt. The 
CICR should also be initialized. 


23.Write 0x00000020 to the GSMR_H to configure a small receive FIFO width. 


24.Write 0x00028004 to the GSMR_L to configure 16x oversampling for transmit and 
receive, the CTS and CD pins to automatically control transmission and reception 
(DIAG field) and the SCC2 UART mode. Notice that the transmitter (ENT bit) and 
receiver (ENR bit) have not been enabled yet. 

25.Set the PSMR-SCC2 UART to 0xB000 to configure automatic flow control using the 
CTS pin, 8-bit characters, no parity, 1 stop bit, and asynchronous scC2 UART -_ 
operation. 

26.Write 0x00028034 to the GSMR_L register to enable the SCC2 transmitter and 
receiver. This additional write ensures that the ENT and ENR bits are enabled last. 


Bars 


SCC 
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ag Note: After 16 bytes are transmitted, the TX buffer descriptor is closed. Additionally, 
the receive buffer is closed after 16 bytes are received. Any data received after 
16 bytes causes a busy (out-of-buffers) condition since only one RX buffer 

_ descriptor is prepared. 


16.9.15.22 S-RECORD PROGRAMMING EXAMPLE. The following is an example of a 
downloading application that uses the SCC2 channel as a UART controller.. The application 
performs S-record downloads and uploads between a host computer and an intelligent 
peripheral through a serial asynchronous line. The S-records are strings of ASCII characters 
that begin with ‘S’ and end in an end-of-line character. This characteristic is used to impose 
a message structure on the communication between the devices. Each device can transmit 
XON and XOFF characters for flow control, which do not form part of the program being 
uploaded or downloaded. 


The PSMR—SCC2 UART register should be set as needed with the FRZ bit cleared and the 
ENT and ENR bits set. Receive buffers should be linked to the receive buffer table with the 
| bit set. For simplicity, assume that the line is not multidrop (no addresses are transmitted) 
and that each S-record fits into a single data buffer. Three characters should first be entered 
into the SCC2 UART control character table: 


e Line Feed—Both the E and R bits should be cleared. When an end-of-line character is 
received, the current buffer is closed and made available to the core for processing. 
This buffer contains an entire S record that the processor can now check and copy to 

memory or disk as required. 


e XOFF—E should be cleared and R should be set. whenever the core receives a control 
character received interrupt and the receive control character register contains XOFF, 
the software should immediately stop transmitting to the other station by setting the FRZ 
bit in the PSMR-—SCC2 UART. This prevents data from being lost by the other station 
when it runs out of receive buffers. 


¢ XON—This character should be received after XOFF. The E bit should be cleared and 
the R bit should be set. The FRZ bit on the transmitter should now be cleared. The 
communication processor module automatically resumes transmission of the serial line 
at the point at which it was previously stopped. Like XOFF, the XON character | is not 
stored in the receive buffer. 


To receive the S- records, the core must only wait for the receive interrupt, thus ndleating 
that a complete S-record buffer has been received. Transmission requires assembling 


_ S-records into data buffers and linking them to the transmit buffer table and it can be 


temporarily stopped when an XOFF character is received. This scheme minimizes the 
number of interrupts received by the core (one per S- -record) and relieves it from the task of 
cone scanning for control mec 


16-226 | -MPC823 USER’S MANUAL MOTOROLA 


Communication Processor Module 


16.9.16 The SCC2 In HDLC Mode 


Layer 2 of the seven-layer open systems interconnection (OSI) model from ISO is the data 
link layer and one of the most common protocols in this layer is high-level data link control 
(HDLC). In fact, many other common layer 2 protocols—SDLC, SS#7, AppleTalk, LAPB, 
and LAPD—are based on HDLC and its framing structure in particular. The framing structure 
of HDLC is illustrated in Figure 16-76. 


HDLC uses a zero insertion/deletion process (commonly known as bit-stuffing) to ensure 
that the bit pattern of the delimiter flag does not occur in the fields between flags. The HDLC 
frame is synchronous and relies on the physical layer to provide a method for clocking and 
synchronizing the transmitter/receiver. 


Since the layer 2 frame can be transmitted over a point-to-point link, a broadcast network, 
or packet and circuit switched systems, an address field is needed to carry the frame's 
destination address. The length of this field is commonly 0, 8, or 16 bits, depending on the 
data link layer protocol. For instance, SDLC and LAPB use an 8-bit address and SS#7 has 
no address field at all because it is always used in point-to-point signaling links. LAPD 
further divides its 16-bit address into different fields to specify various access points within 
one piece of equipment. It also defines a broadcast address. some HDLC- -type protocols 
allow for extended addressing beyond 16 bits. | 


The 8- or 16-bit control field provides a flow control number and defines the frame type 
(control or data). The exact use and structure of this field depends on the protocol using the 
frame. Data is transmitted in the data field and its length is dependent on the protocol of the 
_ frame. Layer 3 frames are carried in this data field. Error control is implemented by 
appending a cyclic redundancy check (CRC) to the frame, which in most protocols is 16 bits 
long but can be as long as 32 bits. In HDLC, the least-significant bit of each octet is 
transmitted first and the most-significant bit of the CRC is transmitted first. 


When the MODE field of the GSMR_L selects the HDLC mode, the serial communication 
controller is functioning in HDLC mode. When you use an SCC2 in HDLC mode with a 
nonmultiplexed modem interface, the serial communication controller outputs are connected 
directly to the external pins. Modem signals can be supported through the port B and C pins. 
The receive and transmit clocks can be supplied from either the bank of baud rate 
generators, by the DPLL, or externally. You can also connect the SCC2 in HDLC mode to 
the TDM channel of the serial interface and use it with the time-slot assigner. The SCC2 in 
HDLC mode, also called the SCC2 HDLC controller, consists of separate transmit and 
receive sections whose operations are asynchronous with the core. You can allocate up to 
196 buffer descriptors so that you can transmit or receive many frames without any 
interference from the host. 
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16.9.16.1 FEATURES. The following list summarizes the main features of the SCC2 in 
HDLC mode: 
_ © Flexible data buffers with multiple buffers per frame 
e Separate interrupts for frames and buffers (receive and transmit) 
¢ Received frames threshold to reduce interrupt overhead 
¢ Can be used with the SCC2 DPLL 
_e Four address comparison registers with mask 
_e@ Maintenance of five 16-bit error counters 
e Flag/abort/idle generation or detection 
e Zero insertion/deletion 
© 16- or 32-bit CRC-CCITT generation/checking 
. Detection of nonoctet aligned frames 
¢ Detection of frames that are too long 
. Programmable flags (O-1 5) between successive frames 
‘ Automatic retransmission in case of collision 


16.9.16.2 SCC2 HDLC CHANNEL FRAME TRANSMISSION PROCESS.The HDLC 


_ transmitter is designed to work with little or no intervention from the core. When the core 


enables one of the transmitters, it starts transmitting flags or idles as programmed in the 
PSMR-SCC2 HDLC register. The SCC2 HDLC controller polls the first buffer descriptor in 


- the transmit channel buffer descriptor table. When there is a frame to transmit, the SCC2 


HDLC controller fetches the data from memory and starts transmitting the frame after it 

transmits the minimum number of flags that you specify between frames. When the end of 
the current buffer descriptor has been reached and the last buffer in the frame bit is set, the 
CRC and closing flag are appended. In HDLC mode, the least-significant bit of each octet 
and the most-significant bit of the CRC are transmitted first. An HDLC frame is illustrated in 


Figure 16-76. | : 





- BBITS 16 BITS 8 BITS 8N BITS 16 BITS 8BITS | 
Figure 16-76. SCC2 HDLC Framing Structure | 


After a closing flag is transmitted, the SCC2 HDLC controller writes the frame status bits into 
the buffer descriptor and clears the R bit. When you reach the end of the current buffer 
descriptor and the last bit is not set, only the R bit is cleared. In either mode, an interrupt can 
be issued if the | bit in the TX buffer descriptor is set. The SCC2 HDLC controller then 
proceeds to the next TX buffer descriptor in the table. This method allows you to be 
interrupted after each buffer, a specific buffer, or each frame. 
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To rearrange the transmit queue before the communication processor module finishes 
transmitting all of the buffers, issue the STOP TRANSMIT command. This can be useful for 
transmitting expedited data before previously linked buffers or when an error occurs. When 
receiving the STOP TRANSMIT command, the SCC2 HDLC controller stops transmitting 
the current frame and starts transmitting idles or flags. When the SCC2 HDLC controller 
receives the RESTART TRANSMIT command, it resumes transmission. To insert a 
high-priority frame without aborting the current frame, the GRACEFUL STOP TRANSMIT 
command can be issued. A special interrupt can be generated in the event register when 
the current frame is complete. 


16.9.16.3 SCC2 HDLC CHANNEL FRAME RECEPTION PROCESS.The HDLC receiver 
is designed to work with little or no intervention from the core and can perform address 
recognition, CRC checking, and maximum frame length checking. You are free to use the 
received frame to perform any HDLC-based protocol. 


When the core enables one of the receivers, the receiver waits for an opening flag character 
and when it detects the first byte of the frame, the SCC2 HDLC controller compares the 
frame address against the user-programmable addresses. You have four 16-bit address 
registers and an address mask available for address matching. The SCC2 HDLC controller 
compares the received address field to the user-defined values after masking with the 
address mask. The SCC2 HDLC controller can also detect broadcast (all ones) address 
frames if one address register is written with all ones. 


If a match is detected, the SCC2 HDLC controller fetches the next buffer descriptor and if it 
is empty, it starts transferring the incoming frame to the buffer descriptor associated data 
buffer. When the data buffer has been filled, the SCC2 HDLC controller clears the E bit in 
the buffer descriptor and generates an interrupt if the | bit in the buffer descriptor is set. If 
the incoming frame exceeds the length of the data buffer, the SCC2 HDLC controller fetches 
the next buffer descriptor in the table and, if it is empty, continues transferring the rest of the 
frame to this buffer descriptor associated data buffer. 


During this process, the SCC2 HDLC controller checks for a frame that is too long. When 
the frame ends, the CRC field is checked against the recalculated value and written to the 
data buffer. The data length written to the last buffer descriptor in the HDLC frame is the 
length of the entire frame. This enables HDLC protocols that “lose” frames to correctly 
recognize the frame-too-long condition. The SCC2 HDLC controller then sets the last buffer 
in frame bit, writes the frame status bits into the buffer descriptor, and clears the E bit. The 
SCC2 HDLC controller next generates a maskable interrupt, indicating that a frame has 
been received and is in memory. The SCC2 HDLC controller then waits for a new frame. 
Back-to-back frames can be received with only a single shared flag between frames. 


In the received frames threshold (RFTHR) location of the parameter RAM you can configure 
the SCC2 HDLC controller not to interrupt the core until a certain number of frames are 
received. You can combine this function with a timer to implement a timeout if less than the 
threshold number of frames are received. 
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Note: The SCC2 HDLC controller must receive a maximum of eight clocks (after a 
_ frame is received) to complete the reception. | 


16.9.16.4 SCC2 HDLC PARAMETER RAM MEMORY MAP.When configured to operate 
in HDLC mode, the SCC2 overlays the structure used in Table 16-24 with the HDLC 
parameters that are described in Table 16-27 below. | an _ 


Table 16-27. SCC2 HDLC Parameter RAM Memory Map 


rooness [wave worm | oesonrnon 
[Teczesera] res | wea | —sResenes 
[scczaase+e | RET | Hatwors | Fame ranomisson Goutr | 












NOTE: You are only responsible for initializing the items in bold. 
SCC2 base = (IMMR & OxFFFFO000) + 0x3D00. 
All references to registers in the parameter RAM table are actually implemented in the dual-port RAM 
area as a memory-based register. : 
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e C_MASK—For the 16-bit CRC-CCITT, C_MASK should be initialized with 
OxOOOOFOB8. For the 32-bit CRC-CCITT, C_MASK should be initialized with 
OxDEBB20E3. 


¢ C_PRES—For the 16-bit CRC-CCITT, C_PRES should be initialized with OXOOOOFFFF. 
For the 32-bit CRC-CCITT, C_PRES should be initialized with OxFFFFFFFF. 

¢ DISFC, CRCEC, ABTSC, NMARC, and RETRC—These 16-bit (modulo 2'°) counters 
are maintained by the communication processor module. You can initialize them while 
the channel is disabled. The counters are as follows: 
1 DISFC-—Discarded Frame Counter (error-free frames, but no free buffers). 


1 CRCEC-CRC Error Counter. Includes frames not addressed to you or frames S 
received in the BSY condition, but does not include overrun errors. i 


_1 ABTSC—Abort Sequence Counter. 
(4 NMARC—Nonmatching Address Received Counter (error-free frames only). 
1 RETRC—Frame Retransmission Counter (due to collision). 





e MFLR—The SCC2 HDLC controller compares the length of an incoming HDLC frame 
with the user-defined value given in this 16-bit register. If this limit is exceeded, the 
remainder of the incoming HDLC frame is discarded and the LG bit is set in the last RX 
buffer descriptor belonging to that frame. The SCC2 HDLC controller waits until the end 
of the frame and then reports the frame status and length in the last RX buffer 
descriptor. The MFLR is defined as all the in-frame oe between the opening and 
closing flags. : 


e MAX_CNT—A temporary down-counter used to track the frame length. 


e RFTHR—The received frame’s threshold value is used to reduce the interrupt overhead 
that might otherwise occur when a series of short HDLC frames arrives, each causing 
an RXF interrupt. By setting the RFTHR value, you limit the frequency of RXF interrupts, 
which only occurs when the RFTHR value is reached. 


Note: You should provide enough empty RX buffer descriptors to receive the number 
of frames Specitied i in the RFTHR. 





¢ RFCNT—A temporary down-counter oned: to implement the RFTHR feature. 


¢ HMASK, HADDR1, HADDR2, HADDR3, and HADDR4—The SCC2 HDLC controller 
_has five 16-bit registers for address recognition: one mask register and four address 

registers. The SCC2 HDLC controller reads the frame address from the HDLC receiver, 
compares it against the four address register values, and then masks the result with the 
user-defined mask register. A one in the mask register represents a bit position for 
which address comparison should occur and a zero represents a masked bit position. 
When an address match is made, the address and the data following it are written into 
the data buffers. When the addresses are not matched and the frame is error-free, the 
nonmatching address received counter (NMARC) is incremented. 
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e TMP—A temporary register that is only used by the communication processor module. 


¢ TMP_MB—A temporary register that is only used by the communication processor 
module. 


Note: For 8- bit aiiessee the eight high- -order bits in HMASK should be masked out 
~ (cleared). The eight low-order bits of HMASK and HADDRx should contain the 
address byte that immediately follows the opening flag. For, example, to 
recognize a frame that begins Ox7E, 0x68, OxAA, using 16-bit address 
recognition, HADDRx should contain OxAA68 and HMASK should contain 
OxFFFF. Refer to Figure 16-77 for details. 


.16-BIT ADDRESS RECOGNITION <o 8-BIT ADDRESS RECOGNITION 


FLAG ADDRESS | CONTROL ETC 
Ox7E 0x55 0x44 









HMASK | OxFFFF | 7 HMASK 
HADDRY OxAAGS HADDR1| ———sOxXX55 |] 
HADDR2 HADDR2 OxXX55 | 
HADDR3 - OxAA6B : . HADDR3 OxXX55 






HADDR4 — -OxAAB8. —- HADDR4 OxXX55 | 


RECOGNIZES ONE 16-BIT ADDRESS (HADDR1) AND RECOGNIZES A SINGLE 8-BIT ADDRESS (HADDR1) 
THE 16-BIT BROADCAST ADDRESS (HADDR2) | | 


_ Figure 16-77. HDLC Address Recognition Example 


16.9.16.5 PROGRAMMING THE SCC2 IN HDLC MODE.The core configures the serial 
communication controller to operate in one of the protocols set in the MODE field of the 


~GSMR_L. The SCC2 HDLC controller uses the same data structure as other modes and it 


supports multibuffer operation and address comparisons. The reception errors are reported 
through the RX buffer descriptor and the transmit errors are reported through the TX buffer 
descriptor. 
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16.9.16.6 SCC2 HDLC COMMANDS.You can program the CPM command register 
(CPCR) with the following commands to transmit data. 


STOP TRANSMIT—After the hardware or software is reset and the channel is enabled 
in the PSMR-—SCC2 HDLC register, the channel is in transmit enable mode and starts 
polling the first buffer descriptor in the table every 64 transmit clocks or immediately if 


the TOD bit is set in the transmit-on-demand register (TODR). The channel STOP 


TRANSMIT command disables the transmission of frames on the transmit channel. If 
the SCC2 HDLC controller receives this command while a frame is transmitting, 
transmission is aborted after a maximum of 64 additional bits and the transmit FIFO is 
flushed. The TBPTR is not advanced, no new buffer descriptor is accessed, and no new 
frames are transmitted for this channel. The transmitter transmits an abort sequence 
consisting of 01111111 (if the command was given during frame transmission) and 
begins transmitting flags or idles, as indicated by the PSMR-—SCC2 HDLC register. 


Note: If the MFF bit in the PSMR-SCC2 UART is set, one or more small frames can 
be flushed from the transmit FIFO. Issue the GRACEFUL STOP TRANSMIT 
command to stop this from occurring. 





GRACEFUL STOP TRANSMIT—This command is used to stop transmission 
smoothly, instead of abruptly, like the regular STOP TRANSMIT command. It stops 
transmission after the current frame is finished or immediately if there is no frame being 
transmitted. The GRA bit in the SCCE-HDLLC is set once transmission has stopped. 
Then the HDLC transmit parameters and their buffer descriptors can be modified. The 
TBPTR points to the next TX buffer descriptor in the table. Transmission begins once 
the R bit of the next buffer descriptor is set and the RESTART TRANSMIT command 
is issued. 


RESTART TRANSMIT—This command enables aveciats to be transmitted on the 
transmit channel. The SCC2 HDLC controller expects this command after a STOP 


~ TRANSMIT command is issued or aftera GRACEFUL STOP TRANSMIT command is 


issued or a transmitter error occurs. The SCC2 HDLC controller resumes transmission 
from the current TBPTR in the channel TX buffer descriptor table. 


INIT TX PARAMETERS—This command initializes all transmit parameters in this serial 
channel parameter RAM to their reset state and should only be issued when the 
transmitter is disabled. The INIT TX AND RX PARAMS command can be used to reset 
the transmit and receive parameters. 


MOTOROLA MPC823 USER’S MANUAL — 16-233 


Lu 
wl 
50 
a 
ao 
So 
Sun 
uu 
=o 
.@) 
oa 
oa. 





~ Communication Processor Module 


You can program the CPM command register with the following commands to receive data. 


e ENTER HUNT MODE—Aftter the hardware or software is reset and the channel is 
enabled in the PSMR-—HDLC register, the channel is in receive enable mode and uses 
the first buffer descriptor in the table. The ENTER HUNT MODE command is generally 
used to force the HDLC receiver to stop receiving the current frame and enter hunt 
mode. In hunt mode, the SCC2 HDLC controller continually scans the input datastream 

— for the flag sequence. After receiving the command, the current receive buffer is closed 
and the CRC is reset. Further frame reception uses the next buffer descriptor. 


‘up . | me: CLOSE RX BD—This command should not be used in the HDLC protocol. 


e INIT RX PARAMETERS—This command initializes all the receive parameters in this 
serial channel parameter RAM to their reset state and should only be issued when the 
_ receiver is disabled. The INIT TX AND RX PARAMS command can be used to reset 
the receive and transmit parameters. 


— 





16.9.16.7 SCC2 HDLC CONTROLLER ERRORS. The SCC2 HDLC controller reports 
frame reception and transmission error conditions using the channel buffer descriptors, error 
counters, and SCCE-HDLC register. The following transmission errors can be detected by 
the SCC2 HDLC controller. 


e Transmitter Underrun Error—When this error occurs, the channel terminates buffer 
transmission, closes the buffer, sets the UN bit in the buffer descriptor, and generates 
the TXE interrupt if it is enabled. The channel continues transmitting after it receives the 

~ RESTART TRANSMIT command. The transmit FIFO size is 32 bytes for the serial 
communication controller. 


- @ CTS Lost During Frame Transmission Error—When this error occurs, the channel 
- terminates buffer transmission, closes the buffer, sets the CT bit in the buffer descriptor, 
and generates the TXE interrupt if it is enabled. The channel continues transmitting 
_after it receives the RESTART TRANSMIT commana. If this error occurs on the first or 
second buffer of the frame and the RTE bit in the PSMR—HDLC is set, the channel 
retransmits the frame when the CTS signal becomes active again. When you are 
_ working in SCC2 HDLC mode with the possibility of a collision, in order to ensure the 
retransmission method functions properly, the first and second data buffers should 
contain more than 36 bytes of data and 20 bytes of data if multiple buffers per frame are 
~ used. The channel also increments the retransmission counter. This requirement does 
not apply to small frames that consist of a single buffer. 
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The following reception errors can be detected by the SCC2 HDLC controller. 


e Overrun Error—The SCC2 HDLC controller maintains an internal FIFO for receiving 
data. The communication processor module begins programming the SDMA channel 
and updating the CRC when 8 or 32 bits are received in the FIFO. When a receive FIFO 
overrun occurs, the channel writes the received data byte to the internal FIFO over the 
previously received byte. The previous data byte and the frame status are lost. The 
channel closes the buffer with the OV bit in the buffer descriptor set and generates the 
RXF interrupt if it is enabled. The receiver then enters hunt mode. Even if an overrun : 
occurs during a frame whose address is not matched in the address recognition logic, Fa euae) 
an RX buffer descriptor with a data length of two is epenee to report the overrun and [ oS 
the RXF interrupt is generated if it is enabled. oe 





e CD Lost During Frame Reception Error—When this error occurs, the channel 
terminates frame reception, closes the buffer, sets the CD bit in the RX buffer 
descriptor, and generates the RXF interrupt if it is enabled. This error has the highest 
priority. The rest of the frame is lost and other errors are not checked in that frame. At 
this point, the receiver enters hunt mode. 


e Abort Sequence Error—This error occurs when seven or more consecutive ones are 
received. When it does occur and the SCC2 HDLC controller receives a frame, the 
channel closes the buffer by setting the AB bit in the RX buffer descriptor and 
generating the RXF interrupt, if enabled. The channel also increments the abort 
sequence counter. The CRC and nonoctet error status conditions are not checked on 
aborted frames. The receiver then enters hunt mode. When an abort is received, you 
are given no indication that an SCC2 HDLC controller is not currently receiving a frame. 


e Nonoctet Aligned Frame Error—When this error occurs, the channel writes the received 
data to the data buffer, closes the buffer, sets the NO bit in the RX buffer descriptor, and 
generates the RXF interrupt if itis enabled. The CRC error status should be disregarded 
on nonoctet frames. After a nonoctet aligned frame is received, the receiver enters hunt 
mode. An immediate back-to-back frame is still received. The nonoctet data may be 
derived from the last word in the data buffer as follows: 


MSB | | LSB 


a ee 
<—_————_-valid data———————_> <—————_nonvalid data——————_> 


ay 4 Note: If you are using the data buffer swapping option, the above diagram refers to the 
a last byte of the data buffer, not the last word. In SCC2 HDLC mode, the LSB of 
each octet is transmitted first and the MSB of the CRC is transmitted first. 


e CRC—When this error occurs, the channel writes the received CRC to the data buffer, 
closes the buffer, sets the CR bit in the RX buffer descriptor, and generates the RXF 
interrupt if it is enabled. The channel also increments the CRC error counter. After 
receiving a frame with a CRC error, the receiver enters hunt mode. An immediate back- 
to-back frame is still received. CRC checking cannot be disabled, but the CRC error can 
be ignored if checking is not required. 
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16.9.16.8 SCC2 HDLC MODE REGISTER.When the SCC2 is in HDLC mode, the 16-bit, 
memory-mapped, read/write protocol-specific mode register is referred to as the SCC2 
HDLC mode register (PSMR-—SCC2 HDLC). Since each protocol has specific Seance 
the PSMR bits are different for each UnpIoMentavon: 


PSMR-SCC2 HDLC 


_(IMMR & OxFFFFO000) + 0xA28 





NOF—Number of Flags 


This field signifies the minimum number of flags | peiween or before frames. If NOF = 0000, 
then no flags are inserted between the frames. Thus, the closing flag of one frame is 
immediately followed by the opening flag of the next frame in the case of back-to-back 
frames. These bits can be modified on-the-fly. | 


CRC—CRC Selection 


00 = 16-bit CCITT-CRC (HDLC). X16 + X12 + X5 +1. 
01 = Reserved. | | 
10 = 32-bit CCITT-CRC (Ethernet and HDLC). X32 + X26 + X23 + X22 + X16 + X12 + 
X11 Ogee Ne ne +1. 
11= Reserved. 


RTE—Retransmit Enable 


O= Noretransmission. __ | 
1 = Automatic frame retransmission is enabled. Retransmission only occurs if the lost 
CTS occurs on the first or second buffer of the frame. 


Bits 7 and 13-15—Reserved 
These bits are reserved and should be set to 0. 


FSE—Flag Sharing Enable. 
This bit is only valid if the RTSM bit is set in the GSMRF_H. This bit can be modified on-the-fly. 


0- = Normal operation. 
= If NOFO—NOF3 = 0000, then a single shared flag is transmitted between 
_ back-to-back frames. Other values of NOFO-NOFS are decremented by 1 when 
this bit is set. This is useful in Signaling System #7 (SS#7) applications. 
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DRT—Disable Receiver While Transmitting 


O= 


Normal operation. 


1 = While data is being transmitted by the serial communication controller, the receiver 


is disabled. This configuration is useful if the HDLC channel is configured onto a 
multidrop line and you do not want to receive your own transmission. 


BUS—HDLC Bus Mode 


O0= 
t= 


Normal HDLC operation. | 
HDLC bus operation is selected. Refer to Section 16.9.17 The HDLC Bus 
Controller for more details. 


BRM—HDLC Bus RTS Mode 
This bit is only valid if BUS = 1. Otherwise, it is ignored. 


0O= 


1 = 


Normal RTS operation during HDLC bus mode. RTS is asserted on the first bit of 
the transmit frame and negated after the first collision bit is received. 

Special RTS operation during HDLC bus mode. RTS is delayed by one bit with 
respect to the normal case. This is useful when the HDLC bus protocol is being run 
locally and transmitted over a long-distance transmission line at the same time. 
Data can be delayed one bit before it is sent over the transmission line, thus RTS 
can be used to enable the transmission line buffers. The result is a clean signal 
level sent over the transmission line. | 


MFF—Multiple Frames in FIFO 


O= 


5 


Normal operation. The transmit FIFO must never contain more than one HDLC 
frame. The CTS lost status is reported accurately on a per-frame basis. The 
receiver is not affected by this bit. 

The transmit FIFO can contain multiple frames, but lost CTS is not guaranteed to 
be reported on the exact buffer/frame it truly occurred on. This option, however, 
can improve the performance of HDLC transmissions of small back-to-back frames 
or in cases where you prefer to limit the number of flags transmitted between 
frames. The receiver is not affected by this bit. 


16.9.16.9 SCC2 HDLC RECEIVE BUFFER DESCRIPTOR.The SCC2 HDLC controller 
uses the receive (RX) buffer descriptor to report information about the data received for each 
buffer. An example of the RX buffer descriptor process is illustrated in Figure 16-78. 





Note: The communication processor module sets all the status bits in this buffer 
descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 
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MRBLR = 8 BYTES FOR SCC2 
RECEIVE BD 0 | 
L oF BUFFER 


ADDRESS 1 | 
ADDRESS 2 











STATUS 






















































LENGTH CONTROL BYTE 8 BYTES 
BUFFER 5 
INFORMATION 
en (|-FIELD) BYTES 
BUFFER = 
sini LAST |-FIELD BYTE 
CRC BYTE 1 
LENGTH 8 BYTES 
BUFFER 
| CLOSED WHEN 
Poniee CLOSING FLAG 
RECEIVED 
ee ADDRESS 1 ZY 
: ADDRESS 2 
LENGTH CON Eee 8 BYTES 
ABORT WAS 
soit RECEIVED 
BUFFER 
STATUS 
LENGTH 
BUFFER EG IES 
| STILL 3 
POINTER 32-BIT BUFFER POINTER EMPTY 
- 3 : STORED IN RX BUFFER 
STORED IN RX BUFFER _ 
LINE IDLE ABORT/IDLE 


TWO FRAMES 
_ RECEIVED IN HDLC UNEXPECTED ABORT PRESENT 
TIME——> | OCCURS BEFORE TIME 
| CLOSING FLAG 
LEGEND: 
F = FLAG 


A= ADDRESS BYTE 

C = CONTROL BYTE 

| = INFORMATION BYTE 
CR = CRC BYTE 


Figure 16-78. HDLC Receive Buffer Descriptor Example 
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RX DATA BUFFER POINTER 


NOTE: You are only responsible for initializing the items in bold. 






E—Empty 

O= The data buffer associated with this RX buffer descriptor has been filled with data 
or reception has been aborted because of an error condition. The core is free to 
examine or write to any fields of this RX buffer descriptor. The communication 
processor module does not use this buffer descriptor as long as the E bit is zero. 

1 = The data buffer associated with this buffer descriptor is empty or is currently . 
receiving data. This RX buffer descriptor and its associated receive buffer are 
owned by the communication processor module. Once the E bit is set, the core 
should not write any fields of this RX buffer descriptor. | 


Bits 1, 7, and 9—Reserved | 
These bits are reserved and should be set to 0. 


W-—Wrap (Final Buffer Descriptor in Table) 


0= This is not the last buffer descriptor in the RX buffer descriptor table. 

1 = This is the last buffer descriptor in the RX buffer descriptor table. After this buffer 
is used, the communication processor module receives incoming data into the first 
buffer descriptor that RBASE points to in the table. The number of RX buffer 
descriptors in this table are programmable and determined only by the W bit and 
overall space constraints of the dual-port RAM. 


I—Interrupt 
0 = The RXB bit is not set after this buffer is used, but RXF operation remains 
unaffected. 


1 = The RXB or RXF bit in the SCCE—-HDLC register is set when the SCC2 HDLC 
controller uses this buffer. These two bits can cause interrupts if they are enabled. 


|—Last in Frame 


This bit is set by the SCC2 HDLC controller when this buffer is the last one in a frame. This 
implies the reception of a closing flag or reception of an error, in which case one or more of 
the CD, OV, AB, and LG bits are set. The SCC2 HDLC controller writes the number of frame 
octets to the data length field. 


0 = This buffer is not the last one in a frame. 
1 = This buffer is the last one in a frame. 
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F—First in Frame | - 
This bit is set by the SCC2 HDLC controller when this buffer is the first in a frame. 


O = The buffer is not the first one in a frame. 
1 = The buffer is the first one in a frame. 


CM—Continuous Mode 


O = Normal operation. 

1= The E bit is not cleared by the communication processor module after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
overwritten next time the communication processor module accesses this buffer 
descriptor. The E bit is cleared if an error occurs during reception, regardless of 
how the CM bit is set. 


DE—DPLL Error 


This bit is set by the SCC2 HDLC controller when a DPLL error occurs while this buffer is 
being received. In decoding modes where a transition is promised every bit, the DE bit is set 
when a missing transition occurs. 


LG—RX Frame Length Violation 


This bit indicates when a frame length greater than the maximum defined for this channel is 
recognized and only the maximum-allowed number of bytes (MFLR) is written to the data 
buffer. This event is not reported until the RX buffer descriptor is closed, the RXF bit is set, 
and the closing flag is received. The actual number of bytes received between flags is 
written to the data length field of this buffer descriptor. 


NO—RX Nonoctet Aligned Frame 


This bit indicates when a frame is received that contains a number of bits almost divisible by 
eight. 


AB—RX Abort Sequence 


This bit indicates when a minimum of seven consecutive ones are received when a frame i is 
received. 


CR—RX CRC Error 


This bit indicates that this frame contains a CRC error. The received oee bytes are always 
written to the receive buffer. 


OV—Overrun 
This bit indicates that a receiver overrun has occurred while a frame was being received. 


CD—Carrier Detect Lost 


This bit indicates that a carrier detect signal has been negated while a frame was being 
received. This bit is only valid when working in NMSI mode. | 


16-240 | MPC823 USER’S MANUAL MOTOROLA 


Communication Processor Module 


Data Length 


These bits represent the number of octets the communication processor module writes into 
this buffer descriptor data buffer. It is written by the communication processor module once 
the buffer descriptor is closed. When this buffer descriptor is the last buffer descriptor in the 
frame (L = 1), the data length contains the total number of frame octets, including 2 or 4 
bytes for CRC. The actual amount of memory allocated for this buffer should be greater than 
or equal to the MRBLR. 


RX Data Buffer Pointer 


These bits always point to the first location of the associated data buffer, they reside in 
internal or external memory, and must be divisible by four. 


16.9.16.10 SCC2 HDLC TRANSMIT BUFFER DESCRIPTOR.Data is sent to the SCC2 
HDLC controller for transmission on an SCC2 channel by arranging it in buffers referenced 
by the channel’s TX buffer descriptor table. Using the transmit (TX) buffer descriptors, the 
communication processor module confirms transmission and indicates error conditions so 
that the core knows the buffers have been serviced. 









| TX DATA BUFFER POINTER : | 


NOTE: You are only responsible for initializing the items in bold. 






Note: The communication processor module sets all the status bits in this buffer 
descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. | 





R—Ready 

O= The data buffer associated with this buffer descriptor is not ready for transmission. 
You are free to manipulate this buffer descriptor or its associated data buffer. The 
communication processor module clears this bit after the buffer has been 
transmitted or an error condition is encountered. 

1 = The data buffer, which you have prepared, has not been transmitted or is currently 
being transmitted. You cannot write any fields of this buffer descriptor once this bit 
is set. | 


MOTOROLA — MPC823 USER’S MANUAL 16-241 


i. 
es 
{Cy 
(Cy 
Hage 
iW 


wi 
a | 
a 
SO 
— 
<—o 
89 
Sn 
nn 
=e) 
=O 
Om 
On 








38 
or 
Oz 
me 
Pe 
olen 
> 
so 
J 
OO 
oa 
c 

| 





- Communication Processor Module 


Bits 1 and 7—-13—Reserved 
These bits are reserved and should be set to 0.. 


W—Wrap (Final Buffer Descriptor i in Table) 


O= This is not the last buffer descriptor in the TX buffer descrinian table. 

1 = This is the last buffer descriptor in the TX buffer descriptor table. After this buffer 
has been used, the communication processor module transmits data from the first. 
buffer descriptor that TBASE points to in the table. The number of TX buffer 
descriptors in this table are programmable and determined only by the W bit and 
overall space constraints of ie dual-port RAM. 


I—Interrupt 


0 = No interrupt is generated after this buffer is serviced. 
1 = The TXB or TXE bit in the SCCE—HDLC register is set when this buffer is serviced 
by the SCC2 HDLC controller. These bits can cause interrupts if they are enabled. 


|_—Last 


O = This is not the last buffer in the frame. 
1 = This is the last buffer in the frame. 


Tex CRC 
This bit is valid only when the L bit is set. Otherwise, it is ignored. 


O= Transmit the closing flag after the last data byte. This setting can be used to send 
a bad CRC after the data for testing purposes. 
1 = Transmit the CRC sequence after the last data byte. . 


CM—Continuous Mode 


O = Normal operation. 

1= The R bit is not cleared by the communication processor module after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
retransmitted next time the communication processor module accesses this buffer 
descriptor. However, the R bit is cleared if an error occurs during transmission, 
regardless of how the CM bit is set. 


UN—Underrun 


This bit indicates when an SCC2 HDLC controller encounters a transmitter underrun 
condition while transmitting the associated data buffer. The SCC2 HDLC controller writes 
these bits after it finishes transmitting the associated data buffer. 
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CT—CTS Lost 


This bit indicates when CTS in NMSI mode or layer 1 grant is lost in GCI mode during frame 
transmission. lf data from more than one buffer is currently in the FIFO when this error 
occurs, this bit is set in the currently open TX buffer descriptor. The SCC2 HDLC controller 
writes these bits after it finishes transmitting the associated data buffer. 


DATA LENGTH 


These bits represent the number of bytes the SCC2 HDLC controller transmits from this 
buffer descriptor data buffer. It is never modified by the communication processor module. 
The value of this field should be greater than zero. The SCC2 HDLC controller writes these 
bits after it finishes transmitting the associated data buffer. 


TX DATA BUFFER POINTER 


These bits contain the address of the associated data buffer and can be even or odd. The 
buffer can reside in internal or external memory. This value is never modified by the 
communication processor module. The SCC2 HDLC controller writes these bits after it 
finishes transmitting the associated data buffer. | 


16.9.16.11 SCC2 HDLC EVENT REGISTER.When the SCC2 is in HDLC mode, the 16-bit, 
memory-mapped SCC2 event register is referred to as the SCC2 HDLC event register 
(SCCE-HDLC). Since each protocol has specific requirements, the SCCE bits are different 
for each implementation. This register is used to report events recognized by the HDLC 
channel and to generate interrupts. When an event is recognized, the SCC2 HDLC 
controller sets the corresponding bit in this register. Interrupts generated by this register can 
be masked in the SCCM-HDLC register. An example of interrupts that can be generated 
using the HDLC protocol is illustrated in Figure 16-79. | 
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FRAME 
RECEIVED IN HDLC 
TIME—> wag STORED IN RABUPFER 
RXD2 LINEIDLE =F] F/AlA|c] i]t] t [crlcrlr | NE (DEE 


CD. 
‘% HDLC SCCE | 
re EVENTS CD  IDLFLG FLG RXB RXF FLG IDL CD 
deters FLG 
NOTES: 


1. RXB event assumes receive buffers are 6 bytes each. 

2. The second IDL event occurs after 15 ones are received in a row. 

3. The FLG interrupts show the beginning and end of flag reception. 

4. The FLG interrupt at the end of the frame may precede the RXF interrupt due to receive FIFO latency. 
5. The CD event must be programmed in the port C parallel I/O, not in SCC2 itself. 

6. F = flag, A = address byte, C = control byte, | = information byte, and CR = CRC byte. 


: FRAME STORED IN 
TRANSMITTED BY HDLC TX BUFFER 
<____>>- 
TxD2 | LINE IDLE LINE IDLE 
RTS | | 
-_ 
HDLC SCCE ae | 
BENS CTs TXB CTS 
NOTES: 


1. TXB event shown assumes all three bytes were put into a single buffer. 
2. Example shows one additional opening flag. This is programmable. 
3. The CTS event must be programmed in the port C parallel I/O, not in SCC2 itself. 


Figure 16-79. HDLC Interrupt Event Example 
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A bit is cleared by writing a 1 (writing a zero has no effect) and more than one bit can be 
cleared at a time. Also, all unmasked bits must be cleared before the communication 
processor module clears the internal interrupt request. This register is cleared at reset and 
can be read at any time. : 


SCCE-HDLC 


fesenven [aun] out) ooc |e | [om esenven| ne | [sy |e [ee 
ce ea ee 
aw z 


ew aw [a [ow aw [aw] aw —[ mw fw | 


(IMMR & OxFFFF0000) + 0xA30 





Bits 0-2 and 9-10—Reserved 
These bits are reserved and should be set to 0. 


GLR—Glitch on RX 


This bit indicates that the serial communication sonirallet has delaciee a rclock « glitch on the 
receive clock. 


GLT—Glitch on TX 


This bit indicates that the serial communication eonreler has detected a clock glitch on the 
transmit clock. 


DCC—DPLL Carrier-Sense Changed 


This bit indicates that the carrier-sense status generated by the DPLL has changed state. 
Its real-time status can be found in the SCCS-HDLC register. This is not the CD pin status 
that is reported in port C and it is only valid when the DPLL is used. 


_FLG—Flag Status 


This bit indicates when the SCC2 HDLC controller stops or starts receiving HDLC flags. Its 
real-time status can be obtained in the SCCS—HDLC register. 


IDL—Idle Sequence Status Changed 


This bit indicates when a change in the status of the serial line occurs on the HDLC line. The 
real-time status of the line can be read in the SCCS—HDLC register. 


GRA—Graceful Stop Complete 


this bit indicates that a graceful stop, which was initiated by the GRACEFUL STOP 
TRANSMIT command, has completed. This bit is set as soon as the transmitter finishes 
transmitting any frame that was in progress when the command was issued. It is set 
immediately if no frame was in progress when the command was issued. 


TXE—TX Error 
This bit indicates that an error has occurred on the transmitter eatin: 
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RXF—RX Frame 


This bit indicates when a complete frame is received on the HDLC channel. This bit is set 
no sooner than two clocks after the last bit of the closing flag is received. 


BSY—Busy Condition 
This bit indicates when a frame has been received and discarded due to a lack of buffers. 


TXB—Transmit Buffer 


This bit indicates that a buffer has been transmitted on the HDLC channel. This bit is set no 
sooner than when the last bit of the closing flag begins its transmission if the buffer is the 
last one in the frame. Otherwise, this bit is set after the last byte of the buffer is written to the 
transmit FIFO. | | 


RXB—Receive Buffer 
This bit indicates that the HDLC channel received a buffer that is not a complete frame. 


16.9.16.12 SCC2 HDLC MASK REGISTER.When the SCC2 is in HDLC mode, the 16-bit, 
read/write SCC2 mask register is referred to as the SCC2 HDLC mask register 
(SCCM-HDLC). It has the same bit formats as the SCCE-—HDLC register. If a bit in this 


register is a 1, the corresponding interrupt in the SCCE—HDLC register is enabled. If the bit 


is zero, the corresponding interrupt in the SCCE—HDLC is masked. 


SCCM—-HDLC 
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16.9.16.13 SCC2 HDLC STATUS REGISTER. The 8-bit read-only SCC2 status register is 
referred to as the SCC2 HDLC status register (SCCS—HDLC). Since each protocol has 
specific requirements, the SCCS bits are different for each implementation. This register 
allows you to monitor real-time status conditions on the RXD2 line. The real-time status of 
the CTS and CD pins are part of the port C parallel I/O. 


Pp eserves 
ee eee ee ee 
ea Ee ee 


Bits 0-4—Reserved 
These bits are reserved and should be set to 0. 


SCCS-HDLC 










FG—Flags 

When this bit is cleared, the most recently received 8 bits are examined every bit time to see 
if a flag is present. FG is set as soon as an HDLC flag (0x7E) is received on the line and 
once itis set, it remains set at least 8 bit times and the next eight received bits are examined. 
lf another flag occurs, this bit stays set for at least another eight bits. Otherwise, it is cleared 
and the search begins again. The line is checked after the data has been decoded by the 
DPLL. 


0 = HDLC flags are not being received. 
. 1= HDLC flags are being received. 


CS—Carrier Sense (DPLL) 
This bit shows the real-time carrier sense of the line as determined by the DPLL. 


0 = The DPLL does not sense a carrier. 
1= The DPLL senses a carrier. 


ID—Idle Status 


This bit is set when the RXD2 pin is a logic one for 15 or more consecutive bit times. It is | 
cleared after a single logic zero is received. 


O= The pin is busy. | 
1 = The pin is idle. 
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— 16.9.16.14 SCC2 HDLC PROGRAMMING EXAMPLE #1.The following initialization — 
sequence is for an SCC2 HDLC channel with an external clock. The SCC2 in HDLC mode 
is configured with the RTS2, CTS2, and CD2 pins active and the CLK pin is used for both 
the HDLC receiver and transmitter. 





1. Configure the port A pins to enable the TXD2 and RXD2 pins. Write PAPAR bits 13 
and 12 with ones and then write PADIR and PAODR bits 13 and 12 with zeros. 


2. Configure the port C pins to enable RTS2, CTS2, and CD2. Write PCPAR bit 14 with 
one, and bits 9 and 8 with zeros, PCDIR bits 14, 9, and 8 with zeros, and PCSO bits 





on 9 and 8 with ones. 
3 } 3. Configure port A to enable the CLKS pin. Write PAPAR bit 5 with a one and PADIR bit 
5 with a zero. 


4. Connect the CLK3 pin to SCC2 using the serial interface. Write the R2CS and T2CS 
bits in the SICR to 110. 


5. Connect the SCC2 to the NMSI (its own set of pins) and clear the SC2 bit in the SICR. 
6. Write 0x0001 to the SDCR to set the SDMA bus arbitration level to 5. 


7. Write RBASE and TBASE in the SCC2 parameter RAM to point to the RX buffer 
descriptor and TX buffer descriptors in the dual-port RAM. Assuming one RX buffer 
descriptor at the beginning of dual-port RAM and one TX buffer descriptor following it, 
write RBASE with 0x2000 and TBASE with 0x2008. 


8. Program the CPCR to execute the INIT RX AND TX PARAMS command for the serial 
communication controller. This command causes the RBPTR and TBPTR parameters 
of the serial channel to be updated with the new values just programmed into RBASE 
and TBASE. 


9. Write 0x18 to RFCR and 0x18 to TFCR for normal operation. 


10.Write MRBLR with the maximum number of bytes per receive buffer. Assume 256 
bytes, so MRBLR = 0x0100. The value 256 is chosen so that an entire receive > frame 
can fit into one receive buffer. , 


11.Write OxOOOOFOB8 to C_MASK to comply with 16-bit CCITT-CRC. 
12.Write OxXOOOOFFFF to C_PRES to comply with 16-bit CCITT-CRC. 
13. Clear DISFC, CRCEC, ABTSC, NMARC, and RETRC for clarity. 
14.Write 0x0100 to MFLR so the maximum frame size is 256 bytes. 
15.Write 0x0001 to RFTHR to allow interrupts after each frame. 

16. Write 0x0000 to HMASK to allow all addresses to be recognized. 
17.Clear HADDR1, HADDR2, HADDR3, and HADDR4 for clarity. | 


18. Initialize the RX buffer descriptor. Assume the RX data buffer is at 0x00001 000 in main 
memory. Write OxBO00 to RX_BD_Status, write 0x0000 to RX_BD_Length (not 
required), and 0x00001000 to RX_BD_Pointer. 


19. Initialize the TX buffer descriptor. Assume the TX data frame is at Ox00002000 in main 
memory and contains five 8-bit characters. Write OxBCOO to TX_BD_Status, 0x0005 
to TX_BD_Length, and 0x00002000 to TX_BD_Pointer. 
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20. Write OxFFFF to the SCCE—HDLC to clear any previous events. © 
21.Write 0x001A to the SCCM-—HDLC to enable the TXE, RXF, and TXB interrupts. 


22.Write 0x20000000 to the CIMR to allow SCC2 to generate a system interrupt. The 
CICR should also be initialized. 


23. Write 0x00000000 to the GSMR_H to enable normal behavior of the CTS and CD pins 
and idles between frames (as opposed to flags). 


24. Write 0x00000000 to the GSMR_L to configure the CTS and CD pins to Sitaniaticaly 
control transmission and reception and the HDLC mode. Normal operation of the 
transmit clock is used. Notice that the transmitter (ENT) and receiver (ENR) have not vey 
been enabled. If inverted HDLC operation is preferred, set the RINV and TINV bits in \ re 
the GSMR_L. er 


25. Set the PSMR-HDLC to 0x0000 to configure one opening and one closing flag, 16-bit 
CCITT-CRC, and prevention of multiple frames in the FIFO. . 


26. Write 0x00000030 to the GSMBRB_L to enable the SCC2 transmitter and receiver. This 
additional write ensures that the ENT and ENR bits are enabled last. | 


Note: After 5 bytes and CRC have been transmitted, the TX buffer descriptor is 
automatically closed. Once a complete frame is received, the RX buffer 
descriptor is closed. Any data received after 256 bytes or a single frame causes 
a busy (out-of-buffers) condition since only one RX buffer descriptor is prepared. 





16.9.16.15 SCC2 HDLC PROGRAMMING EXAMPLE #2.The following initialization 
sequence is for an SCC2 HDLC channel that uses the DPLL in a Manchester encoding. You 
must provide a clock that is 16x the preferred bit rate on the CLK3 pin. CLK is then 
connected to the HDLC transmitter and receiver. A baud rate generator could also be used. 
The SCC2 HDLC controller is configured with the RTS2, CTS2, and CD2 pins active. 





1. Follow steps 1 through 22 in example #1 above. 


2. Write 0x00000000 to the GSMR_H to enable normal behavior of the CTS and CD pins 
and idles between frames. 


3. Write Ox004AA400 to the GSMR_L to configure the carrier sense as always active, a 
16-bit preamble of “O1” pattern, 16x operation of the DPLL for the receiver and | 
transmitter, Manchester encoding for the receiver and transmitter, and HDLC mode. | 

The CTS and CD pins should also be configured to automatically control transmission 
and reception. Notice that the transmitter (ENT) and receiver (ENR) have not been 
enabled yet. 


4. Set the PSMR-HDLC to 0x0000 to configure one opening and one closing flag, 16-bit 
CCITT-CRC. Multiple frames in the FIFO are not allowed in this example. | 


5. Write Ox004AA430 to the GSMF_L to enable the SCC2 transmitter and receiver. This 
~ additional write ensures that the ENT and ENR bits are enabled last. 
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Note: After 5 bytes in the preamble have been transmitted, the TX buffer descriptor Is 
automatically closed. Once 16 bytes have been received, the RX buffer 
descriptor is closed. Any data received after 16 bytes causes a busy 
(out-of-buffers) condition since only one RX buffer descriptor is prepared. 


16.9.17 The HDLC Bus Controller 


The HDLC bus is an enhancement that makes it easy to implement an HDLC-based LAN 
and other point-to-multipoint configurations. Most HDLC-based controllers only provide 
point-to-point communications. The HDLC bus is based on the techniques used in the 
CCITT ISDN 1.430 and ANSI T1.605 standards for D channel point-to-multipoint operation 
over the S/T interface. However, the HDLC bus is not fully compliant with 1.430 or T1.605 
and cannot be used to replace devices that implement these protocols. Instead, it is more 
suited to fulfill the needs of non-ISDN LAN and point-to-multipoint configurations. 


You should review the basic features of the 1.430 and T1.605 before learning about the 
HDLC bus. The 1.430 and T1.605 define a method whereby eight terminals can be 
connected over the D-channel of the S/T bus of ISDN. The protocol used at layer 2 is a 
variant of HDLC, called LAPD. However, at layer 1, a method is provided that allows the 
eight terminals to access the physical S/T bus so they can send frames to the switch. _ 


To find out if a channel is clear, the S/T interface device looks at an “echo” bit on the line 
designed to echo the last bit transmitted on the D channel. Depending on the “class” of the 


terminal and the particular situation, the S/T interface device can wait for 7, 8, 9, or 10 ones 


on the echo bit before allowing the LAPD frame to begin transmission. Once transmission 

begins, the S/T chip monitors the data that is sent and if the echo bit matches the transmitted 
data, transmission continues. If the echo bit is ever zero when the transmit bit is 1, then a 

collision will occur between terminals and the station that transmitted a zero will no longer 
transmit. The station that transmitted a one, however, continues as normal. 


The 1.430 and T1.605 provide a physical layer protocol that allows multiple terminals to 
share the same physical connection. Where collisions are concerned, these protocols use 


~ the bus efficiently because one station is always able to complete its transmission. Once a 


station completes a transmission, it lowers its own priority to give other devices fair access 
to the physical connection. | 
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The HDLC bus works pretty much the same way, except for a few differences. First, the 
HDLC bus does not use the echo bit, but rather a separate pin to monitor the data that is 
transmitted. The transmitted data is simply connected to the CTS input. Second, the HDLC 
bus is a synchronous digital open-drain connection for short-distance configurations, rather 
than the more complex configurations of an S/T interface. Third, the HDLC bus allows any 
HDLC-based frame protocol to be implemented at layer 2, not just LAPD. Fourth, the HDLC 
bus devices wait either 8 or 10 bit times before transmitting, rather than 7, 8, 9, or 10 bits. 
Figure 16-80 illustrates HDLC bus in its most common LAN configuration, the multimaster 
configuration. All stations can transmit and receive data to or from every other station on the 
LAN and all transmissions are half-duplex, which is typical in LANs. 


+5 


HDLC BUS LAN 


RXD2 TXD2 CTS RXD2 TXD2 CTS 


RXD2 TXD2 CTS 





HDLC BUS 
CONTROLLER 


HDLC BUS 


HDLC 
CONTROLLER CONTROLLER 





MASTER _ MASTER MASTER 


NOTES: 
1. Transceivers may be used to extend the LAN size, if necessary. 
2. The TXD2 pins of slave devices should be configured to open-drain in the port C parallel 1/O port. 


Figure 16-80. Typical HDLC Bus Multimaster Configuration 
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In single-master configuration, a master station transmits to any slave station without any 
collisions. The slaves only communicate with the master, but can experience collisions in 
their access over the bus. In this configuration, a slave that communicates with another 
‘slave must first transmit its data to the master, where the data is buffered in RAM and then 
retransmitted to the other slave. The benefit of this configuration, however, is that full-duplex 
operation can be obtained. In a point-to-multipoint environment, this is the preienee 
eomignreuan: ragare £0; 81 illustrates ne single-master configuration. 


+5 





HDLC BUS LAN 


RXD2 TXD2 RXD2 TXD2 CTS RXD2 TXD2 CTS 


















HDLC BUS 
CONTROLLER 


HDLC 


HDLC BUS 


CONTROLLER ~ CONTROLLER 





MASTER ~ SLAVE SLAVE 


_ NOTES: 7 
1. Transceivers may be used to extend the LAN size, if necessary. 
2. The TXD2 pins of slave devices should be configured to open-drain in the port C parallel I/O port. 


_ Figure 16-81. Typical HDLC Bus Single-Master Configuration 


16.9.17.1 FEATURES. The following list contains the main features of the HDLC bus: 


e Superset of the SCC2 in HDLC mode features 

e Automatic HDLC bus access 

e Automatic retransmission in case of a collision 

e May be used with the NMSI mode or a TDM bus 
¢ Delayed RTS mode 
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16.9.17.2 ACCESSING THE HDLC BUS.The HDLC bus ensures an orderly access to the 
bus when two or more transmitters attempt to access it simultaneously. One transmitter is 
always successful in completing its transmission. While in the active condition, the HDLC 
bus controller monitors the bus using the CTS pin. It counts the number of one bits using the 
CTS pin and if a zero is detected, the internal counter is cleared. Once eight consecutive 
ones have been received, the HDLC bus controller starts transmitting on the line. While it is 
transmitting information on the bus, the data is continuously compared with the CTS pin and 
used to sample the external bus. The CTS sample is taken halfway through the bit time 
using the rising edge of the transmit clock. If the transmitted bit is the same as the received 
CTS sample, the HDLC bus controller continues its transmission. If, however, the received 
CTS sample is zero, but the transmitted bit was 1, the HDLC bus controller stops 
transmitting after that bit and returns to active condition. Since the HDLC bus uses a 
wired-OR scheme, a transmitted zero has priority over a transmitted 1. Figure 16-82 
illustrates how the CTS pin is used. 


TCLK 


8 CT) 
(OUTPUT) | . 

: CC) 
(INPUT) 


CTS SAMPLED AT HALFWAY POINT. 
COLLISION DETECTED WHEN 
TXD2 = 1, BUT CTS = 0. 


Figure 16-82. Detecting an HDLC Bus Collision 


lf the source address is included in the HDLC frame and destination address, a predefined 
priority of nodes results. Collisions can be detected no later than the end of the source 
address, if one is included. 


Note: The HDLC bus can be used with many different HDLC-based frame formats. 
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To ensure that all stations gain an equal share of the bus, a priority mechanism is 
implemented on the HDLC bus. Once an HDLC bus node has finished transmitting a frame, 
it waits 10 consecutive one bits, instead of eight, before beginning the next transmission. 
Using this method, all nodes that need to transmit can obtain the bus before a node 
transmits twice. Once a node finds out that 10 consecutive ones have occurred on the bus, 
it tries to transmit and reinstate its original priority of waiting for eight ones. 


16.9.17.2.1 Improving Performance. Since the HDLC bus is used in a wired-OR 
configuration, the limitations of the HDLC bus is determined by the rise time of the one bit. 


aaa e _ Figure 16-83 illustrates a method to increase performance. You must supply a clock that is 
ia} ) _ lower more than it is high, which allows the one bit to have more rise time. 
TCLK 
———— 
TXD2 
S——2 


m ae. 
(INPUT) 


CTS sampled at three quarter point. 
Collision detected when 
TXD2 = 1, but CTS = 0. 


Figure 16-83. Example of a Nonsymmetrical Duty Cycle 
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16.9.17.2.2 Delaying RTS Mode. Sometimes the HDLC bus can be usedin a configuration 
with a local HDLC bus and a standard transmission line that is not an HDLC bus. This 
situation is illustrated in Figure 16-84. The local HDLC bus controllers do not communicate 
with each other, but with a station on the transmission line; yet the HDLC bus protocol is 
used to control access to the transmission line. 






LOCAL HDLC BUS 





(1-BIT DELAY) 


EN 







RXD2 TXD2 CTS RXD2 TXD2 CTS 


HDLC BUS HDLC BUS 
CONTROLLER CONTROLLER 


NOTES: 
1. The TXD2 pins of slave devices should be configured to open-drain in the port C parallel 1/0 port. 
2. The RTS pins of each HDLC bus controller are configured to delayed RTS mode. 


Figure 16-84. HDLC Bus Transmission Line Configuration 


Normally, the RTS pin goes active at the beginning of the opening flag’s first bit. Although 
using the RTS pin is not required, there is a mode on the MPC823. HDLC bus that delays 
the RTS signal by one bit. This mode is selected with the BRM bit in the PSMR-SCC2 HDLC 
register. 


Delayed RTS mode is useful when the HDLC bus connects multiple local nodes to a 
transmission line. If the transmission line driver has a one-bit delay, then the delayed RTS 
line can be used to enable the output of the transmission line driver. The result is that the 
transmission line bits always drive “clean” and without any collisions. RTS timing is 
illustrated in Figure 16-85. 
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COLLISION 


spate ee BTS ae 
RTS ACTIVE FOR ONLY 
2 BIT TIMES 


Figure 16-85. Delayed RTS Mode 


16.9.17.2.3 Using the Time-Slot Assigner. Sometimes the HDLC bus can be used in a 
configuration that has a local HDLC bus and a time-division multiplex transmission line that 
is not an HDLC bus. Figure 16-86 illustrates such a case. The local HDLC bus controllers 
all communicate over time-slots. However, more than one HDLC bus controller is assigned 
to a given time-slot and the HDLC bus protocol controls access during that time-slot. 


+5 


RX ~ LOCAL HDLC BUS 


‘hoes a LE 
TX DRIVER 





CTs CTS 


Q 
>< 
oe 
- 
—l 


HDLC BUS HDLC BUS: HDLC BUS: HDLC BUS 
CONTROLLER CONTROLLER CONTROLLER | CONTROLLER 





NOTES: STATIONS SHARE TIME-SLOT N STATIONS SHARE TIME-SLOT M 


1. All TX pins of slave devices should be configured to open-drain in the port C parallel I/O port. 
2. The TSA in the serial interface of each station is used to configure the preferred time-slot. 
3. You can choose the number of stations to share a time-slot. In this example, two are used. 


Figure 16-86. HDLC Bus Time-Slot Assigner Transmission Line Configuration 
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If the serial communication controller is configured to operate using the time-slot assigner 
of the serial interface, then the data is received and transmitted using the L1TXDA and 
L1RXDA pins. The collision sensing is still obtained from the individual serial communication 
controller CTS pin, so the CTS pin must be configured in port C to connect to the preferred 
serial communication controller. Since the serial communication controller only receives 
clocks during its time-slot, the CTS pin is only sampled during the transmit clock edges of 
the particular serial communication controller time-slot. 


16.9.17.3 HDLC BUS MEMORY MAP AND PROGRAMMING.The HDLC bus on the 
MPC823 is implemented using the SCC2 in HDLC mode with certain bits set. If you want to 
do otherwise, see Section 16.9.16.5 Programming the SCC2 in HDLC Mode for 
information about HDLC mode programming. 


Use the general SCC2 mode high and low registers (GSMR_x) described in 

Section 16.9.2 The General SCC2 Mode Registers to program the HDLC bus controller 
with the following steps: 

Set the MODE field to HDLC mode in the GSMR_L. 

Set the CTSS field to 1 and all other bits to zero or default in the GSMR_H. 

Set the DIAG field for normal operation in the GSMR_L. | 

Set the RDCR and TDCR bits for 1x clock in the GSMR_L. 

Set the TENC and RENC bits for NRZ in the GSMR_L. 

Clear the RTSM bit in the GSMR_H. 

Set the ENT and ENR bits in the GSMR_L, as preferred. 


DY OE ee I 


Use the SCC2 protocol-specific mode register described in Section 16.9.16.8 SCC2 HDLC 
Mode Register to program the HDLC bus controller with the following steps: 

Set the NOF field as preferred. | | 

Set the CRC field to 16-bit CRC CCITT. 

Set the RTE bit. 

Set the BUS bit. 

Set the BRM bit to 1 or zero as preferred. 


So oa NY aS 


Set all other bits to zero or default. 
16.9.17.3.1 HDLC Bus Controller Programming Example. Except for the previously | 


discussed GSMR_x and PSMR-—SCC2 HDLC programming, use the examples in 
Section 16.9.16.14 SCC2 HDLC Programming rene #1. 
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16.9.18 The SCC2 in AppleTalk Mode 


AppleTalk® i is aset of protocols developed by Apple Computer Inc. to provide a LAN service 


~ between Macintosh computers and printers. Although AppleTalk can be implemented over 


a variety of physical and link layers, including Ethernet, the AppleTalk protocols have - 
traditionally been more closely associated with one particular physical and link layer protocol 
called LocalTalk. © 


LocalTalk refers to an HDLC-based link and physical layer protocol that runs at the rate of 
230.4kbps. In this manual, the term AppleTalk controller refers to a support that the MPC823 
provides for the LocalTalk protocol. The AppleTalk controller provides the required frame 


synchronization, bit sequence, preamble, and postamble onto standard HDLC frames. 


These capabilities, as well as the use of the HDLC controller in conjunction with DPLL 
operation in FMO mode, provide the proper connection formats to the LocalTalk bus. 


16. 9.18.1 OPERATING THE LOCALTALK BUS. A LocalTalk frame is basically a modified 


HDLC frame. 





SYNC | HDLC | DEST | SOURCE |CONTRO ne. 16 | CLOSING ABORT 

SEQ | FLAGS | ADDR| ADDR BYTE FLAG |SEQUENCE — 
| 0-600 BYTES garie 1 122 

ares Cae BYTE BYTE BYTE BYTES BYTE ONES 


BYTES | 
Figure 16-87. LocalTalk Frame Format 


The frame begins when a synchronization sequence greater than 3 bits is sent. This © 


sequence consists of at least one logical 1 bit (FMO-encoded) followed by greater than 2 bit 
times of line idle with no particular maximum time specified. The idle time allows LocalTalk 
equipment to sense a carrier by detecting a “missing clock” on the line. The remainder of the 
frame is a typical half-duplex HDLC frame. Two or more flags are sent, which allows for bit, 
byte, and frame delineation or detection. Then, two bytes of address, destination, and | 
source are transmitted, followed by a byte of control and 0 to 600 data bytes. Next, two bytes 
of CRC (described in Section 16.9.16.8 SCC2 HDLC Mode Register) are sent. The. 
LocalTalk frame is then terminated by a flag and a restricted HDLC abort sequence. Then 
the transmitter’s driver is disabled. , —— 


The. control byte within the LocalTalk frame indicates the type of frame. Control byte values 
that range from.0x01 to Ox7f are data frames and control byte values that range from 0x80 
to Oxff are control frames. There are four types of control frames: | 


e ENQ—Enquiry 
e ACK—Endguiry acknowledgment 
e RTS—Redquest to send a data frame 
2 CTS—Clear to send a data frame 
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Frames are sent in groups called dialogs, which are handled by the software. For instance, 
to transfer a data frame, three frames are actually sent over the network. An RTS frame (not 
to be confused with the RS-232 RTS pin) is sent to request the network, then a CTS frame 
is sent by the destination node, and the data frame is sent by the requesting node. These 
three frames comprise one possible type of dialog. Once a dialog has begun, other nodes 
cannot start transmitting until the dialog is complete. Frames within a dialog are transmitted 
with a maximum interframe gap (IFG) of 200 microseconds. Although the LocalTalk 
specification does not state it, there is also a minimum recommended IFG of 50ms. Dialogs 
must be separated by a minimum interdialog gap (IDG) of 400ms. These gaps are 
implemented by the software. 


Depending on the protocol, collisions should only be encountered during RTS and ENQ 
frames. Once frame transmission begins, it is fully transmitted, regardless of whether it 
collides with another frame. ENQ frames are infrequent and only sent when a node powers 
up and enters the network. A higher level protocol controls the uniqueness and transmission 
of ENQ frames. 


In addition to the frame fields, LocalTalk requires that the frame be FMO (differential 
Manchester space) encoded, which requires one level transition on every bit boundary. If 
the value to be encoded Is a logic zero, FMO requires a second transition in the middle of 
the bit time. The purpose of FMO encoding is to avoid having to transmit clocking information 
on a separate wire. With FMO, the clocking information is present whenever valid data is 
present. | 


16.9.18.2 FEATURES. The following list summarizes the features of the SCC2 in 
AppleTalk mode: | 

¢ Superset of the HDLC controller features 

e FMO encoding/decoding 

e Programmable transmission of sync sequence 

e Automatic postamble transmission 

e Reception of sync sequence does not cause extra CD interrupts - 

e Reception is automatically disabled while transmitting a frame 

e Transmit-on-demand feature that expedites frames 

e Connects directly to an RS-422 transceiver 
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-16.9.18.3 CONNECTING TO APPLETALK. The MPC823 connects to LocalTalk and, 


using the TXD2, RTS, and RXD2 pins, is an interface for the RS-422 transceiver. The 
RS-422, in turn, is an interface for the LocalTalk connector. Although it is not shown, a 
passive RC circuit is recommended between the transceiver and connector. Figure 16-88 


illustrates how to connect the MPC823 to LocalTalk. 


MPC823 


TX DATA 
TX ENABLE 


scc2 TXD2 
RTS 


MINI-DIN 8 


RxD? RX DATA 








a a ea a EE A 
ae STORED IN RECEIVE BUFFER : 
ae eee ee re 

aa STORED IN TRANSMIT BUFFER : 


STANDARD HDLC FRAME HANDLING 








Figure 16-88. Connecting the MPC823 to AppleTalk 


The 16x multiplier of a 3.686MHz clock can be generated from an external frequency source 
or from one of the baud rate generators if the resulting output frequency is close to a multiple 
of the 3.686MHz frequency. The MPC823 asserts the RTS signal throughout the duration of 
the frame so that RTS can be used to enable the RS-422 transceiver. 
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16.9.18.4 PROGRAMMING THE SCC2 IN APPLETALK MODE. You can implement the 
SCC2 AppleTalk controller by setting certain bits in the SCC2 HDLC controller. Otherwise, 
you should consult Section 16.9.17 The HDLC Bus Controller for detailed information . 
about how to program the SCC2 HDLC controller. You can use the serial communication 
controllers GSMR, PSMR, or TODR to program the AppleTalk controller. 


Use the general SCC2 mode high and low registers (GSMR_x) described in. 
Section 16.9.2 The General SCC2 Mode Registers to program the AppleTalk controller 
with the following steps: 


1. Set the MODE field in the GSMR_L to AppleTalk. 
2. Set the ENT and ENR bits in the GSMR_L. 


3. Set the DIAG field in the GSMR_L for normal operation, with the CD and CTS pins 
grounded or configured for parallel I/O. This causes CD and CTS to be internally 
asserted to the serial communication controller. 


Set the RDCR and TDCR fields in the GSMR_L to a 16x clock. 
Set the TENC and RENC fields in the GSMR_L to FMO. 

Set the TEND bit in the GSMR_L to 0. 

Set the TPP field in the GSMR_L to 11. 


Set the TPL field to 000 to transmit the next frame with no synchronization sequence 
and to 001 to transmit the next frame with the LocalTalk synchronization sequence. 
For example, data frames do not require a preceding synchronization sequence. This 
field may be modified on-the-fly if the AppleTalk protocol is selected. 


9. Set the TINV and RINV bits in the GSMR_L to zero. 
10.Set the TSNC field in the GSMR_L to 10. 
11.Set the EDGE field to 0. 
~12.Set the RTSM bit in the GSMR_H to O. 
13. Set all other bits to 0 or default. 





Oe eo a 


Use the SCC2 protocol-specific mode register described in Section 16.9.3 Protocol- 
Specific Mode Register to program the AppleTalk controller with the following steps: 


1. Setthe NOF field to 0001 oe giving two flags before frames (one opening vag and 
one additional flag). 

2. Set the CRC field to 16-bit CRC-CCITT. 

3. Set the DRT bit to 1. 

4. Set all other bits to 0 or default. 


Use the transmit-on-demand register described in Section 16.9.5 Transmit-on-Demand 
Register to expedite a transmit frame by setting the TOD bit to 1. 
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16. 9. 18.5 SCC2 APPLETALK PROGRAMMING EXAMPLE. excect for the s phevinllsly 


discussed register programming, use the example! in Section 16.9.16.14 SCC2 ae 


Programming Example #1. 


16.9.19 The SCC2 i in Asynchronous HDLC Mode | 


Asynchronous HDLC is a frame-based protocol that uses HDLC framing techniques i in 
conjunction with UART- -type characters. This protocol is typically used as the physical layer 
for the point-to-point protocol (PPP) and the infra-red link access protocol (IRLAP). Even 
though asynchronous HDLC can be implemented in conjunction with the core, it is more 
efficient and less computationally intensive to allow the communication processor module 
to perform the framing and transparency functions. The SCC2 in ASYNG HDLC mode is 
also referred to as the SCC2 ASYNC HDLC controller. . 


16.9.19.1 FEATURES.The following list summarizes the main features i the SCC2 in 
asynchronous HDLC mode: | | | | 


e Flexible data buffer structure that allows an entire frame or a section of one to be 
transmitted and received 


e Separate interrupts for received frames and transmitted buffers 


Automatic CRC generation and checking 

° Support for nonmultiplexed serial interface control signals 
© Automatic generation of opening and closing flags 
Reception of frames with only one “shared” flag 


Automatic generation and stripping of transparency characters rena to RFC 1549 
using transmit and receive control character maps 


° Programmable opening flag, closing flag, and control escape characters 


e Automatic transmission of the abort sequence after the STOP TRANSMIT command is 
issued 


e Automatic transmission of idle characters between frames 


16.9.19.2 SCC2 ASYNC HDLC CHANNEL FRAME TRANSMISSION PROCESS. The 
SCC2 ASYNC HDLC controller, is designed to work with a minimum amount of intervention 
from the core. and operates similar to the SCC2 in HDLC mode. When the core enables the 
transmitter and sets the R bit in the first transmit buffer descriptor, the SCC2 ASYNC HDLC 
controller fetches the data from memory and starts transmitting the frame. When the 
controller reaches the end of the current buffer descriptor, the CRC and closing flag are 
appended if the L bit in the TX buffer descriptor is set. If the CM bit is clear, the asynchronous 
HDLC transmitter writes the frame status bits into the buffer descriptor and clears the R bit. 
If the | bit is set, the controller sets the TXB bit in the SCCE—ASYNC HDLC register. Thus, 
the | bit can be used to generate an interrupt after each buffer, after a group of buffers, or 
after each complete frame has been transmitted. | 
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If the CM bit in the TX buffer descriptor is set, the SCC2 ASYNC HDLC controller writes the 
signal unit status bits into the buffer descriptor after transmission but it does not clear the R 
bit. The SCC2 ASYNC HDLC controller then proceeds to the next TX buffer descriptor in the 
table. If it is not ready, it waits until it is ready. While the SCC2 ASYNC HDLC controller is 
transmitting data from the buffers, it automatically performs the transparency encoding 
specified by the protocol. This encoding is described in Section 16.9.19.4 Transmitter 
Transparency Encoding. 


~8BITS) §=«68BITS) §«8BITS — M*8BITS 2*8BITS 8 BITS 


Figure 16-89. ASYNC HDLC Frame Structure 


You should issue the STOP TRANSMIT command to rearrange the transmit queue before 
the communication processor module finishes transmitting all the buffers. This can be useful 
when transmitting expedited data prior to previously linked buffers or for error situations. 
When the SCC2 ASYNC HDLC controller receives the STOP TRANSMIT command, it stops 
transmitting and sends the abort sequence. It then transmits idle characters until the 
RESTART TRANSMIT command is given, at which point it resumes transmission with the 
next TX buffer descriptor. 


16.9.19.3 SCC2 ASYNC HDLC CHANNEL FRAME RECEPTION PROCESS. The SCC2 
ASYNC HDLC receiver is designed to work with a minimum amount of intervention from the 
core and can decode the transparency characters, check the CRC of the frame, and detect 
errors on the line and in the controller. When the core enables the receiver, the receiver 
waits for data to be present on the line. When the receiver detects a data byte of the 
incoming frame that was preceded by one or more opening flags, the SCC2 ASYNC HDLC 
controller fetches the next buffer descriptor and if the E bit is set it starts transferring the 
incoming frame into the buffer descriptor associated data buffer. When the data buffer is full, 
the SCC2 ASYNC HDLC controller clears the E bit in the buffer descriptor. If the incoming 
frame exceeds the length of the data buffer, the SCC2 ASYNC HDLC controller fetches the 
next buffer descriptor in the table and, if empty, continues transferring the rest of the frame 
into the associated data buffer. 


During this process, the receiver automatically decodes the transparency character required 
of the SCC2 ASYNC HDLC protocol. This procedure is described in detail in 

Section 16.9.19.5 Receiver Transparency Decoding. When the frame ends, the 
controller checks the incoming CRC field and writes it to the data buffer. It then writes the 
length of the entire frame to the DATA LENGTH field of the last buffer descriptor. The SCC2 
ASYNC HDLC controller sets the L bit, writes the frame status bits into the buffer descriptor, 
and clears the E bit if the CM bit is clear. It then sets the RXF bit in the SCCE-—ASYNC HDLC 
register, which indicates that a frame has been received and is in memory. The SCC2 

~ ASYNC HDLC controller then waits for the start of the next frame which may or may not have 
an opening flag. 
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16.9.19.4 TRANSMITTER TRANSPARENCY ENCODING. The SCC2 ASYNC HDLC 
controller maps characters according to the RFC 1549. It examines the outgoing data bytes 
and performs a transparency algorithm on a given byte if one of the following conditions 


apply: | 
° The byte is a flag (0x7E-PPP, 0xC0/0xC1-IrLAP) 


¢ The byte is a control-escape character (0x7D) 


e The byte has a value between 0x00 and Ox1F and the corresponding bit in the 
TX control character table is set 


When a condition applies, a two-byte sequence is transmitted in place of the byte. The 
sequence consists of the control-escape character (0x7D) followed by the original byte 
exclusive-OR’ed with 0x20. 


16.9.19.5 RECEIVER TRANSPARENCY DECODING. The SCC2 ASYNC HDLC 
controller maps characters according to the RFC 1549. To recover the original data, it 
examines the incoming data bytes and performs the transparency algorithm in the following 
ways: | | | 


e Discards any character that has its corresponding bit set in the RX control character 
map. This character is assumed to have been inserted in the character stream by an 
intermediate device and is not part of the originally transmitted frame. 


e Reverses the transmission transparency sequence by discarding a received 
control-escape character (0Ox7D) and exclusive-OR’ing the following byte with 0x20 
before performing the CRC calculation and writing the byte into memory. 
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Figure 16-90 illustrates the algorithm because there are some cases that are not addressed 
in RFC 1549. 
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Figure 16-90. Reception Flowchart 
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16.9.19.6 EXCEPTIONS TO RFC 1549. The following beheviors do not conform to the 
RFC 1549. | 7 


If an Ox7D is followed by a control character and the control character is not mapped, 
the control character itself is “modified” by the XOR process. The CRC check should 
catch this exception. This is a case where the transmitter control character table differs 
from the receiver. 


In addition to the abort sequence, frames are terminated by the following errors: 


L} Carrier detect lost 
(1 Receiver overrun 
1) Framing error 

Li Break sequence 


lf the invalid sequence is received, the first control escape character is discarded, and 
the second is unconditionally exclusive-OR’ed with 0x20. This sequence is stored in the 
buffer descriptor as Ox5D. 


16.9.19.7 SCC2 ASYNC HDLC IMPLEMENTATION. The following behaviors represent 
the key aspects of the SCC2 ASYNC HDLC controller. | 


Flag Sequence—When transmitting, the controller automatically generates the opening 
and closing flag for the frame. When receiving, the controller strips off the opening and 
closing flag before writing the frame to memory. It receives frames with only one 
“shared” flag between them and ignores multiple flags between frames. 


Address Field—The address field is neither generated nor examined by the microcode 
while transmitting or receiving. The address field of the frame must be included in the 
data buffer that the transmit buffer descriptor points to. Any address field compression, 
expansion, or checking must be performed by the core. 


Control Field—The control field is neither generated nor examined by the microcode 
while transmitting or receiving. The control field of the frame must be included in the 
data buffer that the transmit buffer descriptor points to. Any control field compression, 
expansion, or checking must be performed by the core. 


Frame Check Sequence—When transmitting, the frame check sequence (CRC) is 
automatically appended to the end of the frame before the closing flag is transmitted. 
The frame check sequence is generated on the original frame before the transparency 
characters, start/stop bits, or flags are added. The controller uses a 16-bit CRC-CCITT 
polynomial. When receiving, the frame check sequence is automatically checked. The 
frame check sequence is calculated after any transparency characters, start/stop bits, 
and flags are removed. The controller uses a 16-bit CRC-CCITT polynomial. 


Encoding—The SCC2 ASYNC HDLC controller only supports 8 data bits, one start bit, 
one stop bit, and no parity. This must be programmed in the PSMR-—SCC2 ASYNC 
HDLC register so that bits 2 and 3 are set to 1 for proper operation. 

Time-Fill (Idling)—When transmitting, the SCC2 ASYNC HDLC controller transmits 
IDLE characters when no data is available for transmission. When receiving, the SCC2 
ASYNC HDLC controller ignores IDLE characters. 
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16.9.19.8 SCC2 ASYNC HDLC PARAMETER RAM MEMORY MAP. When configured as 
an SCC2 ASYNC HDLC controller, the serial communication controller overlays the 
structure used in Table 16-24 with the SCC2 ASYNC HDLC parameters described in 
Table 16-28. 


Table 16-28. SCC2 ASYNC HDLC Parameter RAM Memory Map 










NOTE: You are only responsible for initializing the items in bold. 
SCC Base = (IMMR & OxFFFF0000) + 0x3D00. 







C MASK—This value should be initialized with OxOOOOFOB8. 
C_PRES—This value should be initialized with OxOOOOFFFF. 


BOF—This value should be initialized to the beginning of flag character (PPP is Ox7E 
and IRLAP is OxC0). | 


EOF—This value should be initialized to the end of flag character (PPP is Ox7E and 
IrLAP is OxC1). 


ESC—This value should be initialized to the control escape character (PPP is Ox 7D 
and IrLAP is 0x7D). | 


e Reserved—These areas are temporary storage locations for the microcode. They 
should not be initialized or modified. 


ZERO—You must set this field to zero. 
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e RFTHR—The received frames threshold indicates how many frames are received 
before the RXF bit is set in the SCCE—ASYNC HDLC register. 


¢ TXCTL_TBL—The transmit control character table stores the bit array used for the TX 
control character table. Each bit corresponds to a character that should be mapped 
according to RFC 1549. If the bit is set, the character corresponding to that bit is 
mapped and if the bit is not set, the corresponding character is not mapped. The 
transmit control character table should be initialized to zero for IrLAP. 


TXCTL_TBL 


ur Joe oc oto 





COMO 


¢ RXCTL_TBL—The receive control character table stores the bit array used for the RX 
control character table. Each bit corresponds to a character that should be mapped 
according to RFC 1549. If the bit is set, the character corresponding to that bit is 
discarded if received and if the bit is not set, the corresponding character is received 
normally. The receive control character table should be initialized to zero for IrLAP. 


RXCTL_TBL 


non | | on | on | ok |r 


oe 


OOOO 





¢ NOF—This entry should be initialized to the number of opening flags to be transmitted 
at the beginning of a frame. A value of n corresponds to n+1 flags. 
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16.9.19.9 CONFIGURING THE SCC2 ASYNC HDLC PARAMETERS. The SCC2 ASYNC 
HDLC parameters can be configured as described in Section 16.9 The Serial 
Communication Controller through Section 16.9.8 Handling Interrupts In the SCC2, 
except for the changes in the following registers. When you are in asynchronous HDLC 
mode, some of the bits in the GSMR_x and general DSR have different meanings. 


For the SCC2 in ASYNC HDLC mode, the general SCC2 mode high and low register 
(GSMR_x) bit descriptions remain the same, except for: 


~¢ RFW—RX FIFO Width (GSMR_H) 


O = Should not be used. 3 | 

1 = Low-latency operation. The RX FIFO is 8 bits wide and the receive FIFO is one 
quarter its normal size (8 bytes). This allows data to be written to the data buffer 
each time a character is received, without forcing you to wait for 32 bits to be 
received. You must choose this configuration for characiercnentcd protocols like 
UART and asynchronous HDLC. 


e TDCR—Transmit Divide Clock Rate (GSMR_L) 


These bits determine the divider rate of the transmitter. If the DPLL is not ised you 
must choose the 1x value. In asynchronous UART or HDLC mode, you must choose 
8x, 16x, or 32x. You should program these bits to equal the RDCR field in most 
applications. 


00 = Do not use. 

01 = 8x clock mode (do not use for IrLAP). 
10 = 16x clock mode. 

11 = 32x clock mode (do not use for IrLAP). 


¢ RDCR—Receive DPLL Clock Rate (GSNR_L) 


These bits determine the divider rate of the receive DPLL. If the DPLL is not used, you 
must choose the 1x value. In asynchronous UART or HDLC mode, you must choose 
8x, 16x, or 32x. You should program these bits to equal the TDCR field in most 
applications. 


00 = Do not use. 

01 = 8x clock mode (do not use for IrLAP). 
10 = 16x clock mode. | 

11 = 32x clock mode (do not use for IrLAP). 


The data synchronization register (DSR) is reserved in asynchronous HDLC mode. It should 
be set to Ox7E7E. 
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16.9.19.10 SCC2 ASYNC HDLC COMMANDS. You can program the CPM command 
register (CPCR) with the following commands to transmit data. See Section 16.2.7.1 CPM 
Command Register for additional information. After the hardware or software is reset and 
the channel is enabled by the SCCM—ASYNC HDLC register, the channel is in transmit 
enable mode and starts polling the first buffer descriptor in the table every eight transmit bit 
times or immediately if the TOD bit of the TODR is set. 


¢ STOP TRANSMIT—This command transmits the asynchronous HDLC abort sequence 
(PPP—0x7D ;0x7E, IrLAP—Ox7D ;0xC1) and disables the transmission of data. If the 
ASYNC HDLC controller receives this command during frame transmission, the abort 
sequence is put into the FIFO and the transmitter does not try to send any more data 
from the current TX buffer descriptor. The controller also does not advance to the next 
TX buffer descriptor. You determine which buffer descriptor is terminated by examining 
the TBPTR entry in the SCC2 parameter RAM table. However, no new buffer BeSclioie! 
is accessed for this channel. 


Note: Unlike the other MPC823 protocols, the SCC2 ASYNC HDLC controller does not 
flush the FIFO because of the STOP TRANSMIT command. Up to 32 characters 
can be transmitted ahead of the abort sequence. However, this can be avoided 
by programming TFL to 1 in the GSMF_H register. 





GRACEFUL STOP TRANSMIT—This command is not supported by the SCC2 ASYNC 
HDLC controller. 


RESTART TRANSMIT—This command reenables the transmission of characters on 
the transmit channel and the SCC2 ASYNC HDLC controller expects it after a STOP 
TRANSMIT command or transmitter error. The controller continues transmitting from 
the first character in the current transmitter buffer descriptor in the channel’s transmit 
buffer descriptor table. 


INIT TX PARAMETERS—This command initializes all the transmit parameters in this 
serial channel’s parameter RAM to their reset state. It must be issued before the 
transmitter is enabled and should only be issued when the transmitter is disabled. The 
INIT TX AND RX PARAMS command can also be used to reset the transmit and 
receive parameters. 
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You can program the CPM command register (CPCR) with the following commands to 
receive data. After the hardware or software is reset and the channel is enabled by its 
SCCM-—ASYNC HDLC register, the channel is in receive enable mode and uses the first 
buffer descriptor in the table. 


¢ ENTER HUNT MODE—This command is used to force the SCC2 ASYNC HDLC 
controller to close the current RX buffer descriptor if it is being used and enter hunt 
mode. The controller continues receiving after it finds a frame preceded by one or more 
opening flags. 

e CLOSE RX BD—This command is not supported by the SCC2 ASYNC HDLC 

controller. 

INIT RX PARAMETERS—This command initializes all the receive parameters in this 

serial channel’s parameter RAM to their reset state and should only be issued when the 

receiver is disabled. The INIT TX AND RX PARAMS command can also be used to 

reset the receive and transmit parameters. 


16.9.19.11 SCC2 ASYNC HDLC CONTROLLER ERRORS. The SCC2 ASYNC HDLC 
controller reports frame reception and transmission error conditions using the channel buffer 
descriptors and the SCC2 ASYNC HDLC event register. The following transmission error 
can be detected by the SCC2 ASYNC HDLC controller. 


e CTS Lost During Frame Transmission Error—When this error occurs, the channel stops 
transmitting the buffer, closes it, sets the CT bit in the TX buffer descriptor and the TXE 
bit in the SCCE—ASYNC HDLC. The channel continues transmitting from the next TX 
buffer descriptor after the RESTART TRANSMIT command is issued. 


The following reception errors can be detected by the SCC2 ASYNC HDLC controller. 


e Overrun Error—The SCC2 ASYNC HDLC controller maintains an internal 8-byte FIFO 
when the serial communication controller receives data. A receive overrun occurs when 
the communication processor module is unable to keep up with the data rate or the 
SDMA channel is unable to write the received data to memory. The previous data byte 
and the frame status are lost. The controller closes the buffer with the OV-bit in the 
buffer descriptor set and sets the RXF bit in the SCCE—ASYNC HDLC register. The 
receiver then searches for the next frame. 


¢ CD Lost During Frame Reception Error—When this error occurs, the channel stops 
receiving frames, closes the buffer, and sets the CD bit in the buffer descriptor and the 
RXF bit in the SCCE—ASYNC HDLC register. This error has the highest priority. The 
rest of the frame is lost and other errors are not checked in that frame. The receiver then 
searches for the next frame once the CD signal is reasserted. 


e Abort Sequence Error—This error occurs when the SCC2 ASYNC HDLC controller 
receives an abort sequence. At that time, the channel closes the buffer by setting the 
RX AB bit in the buffer descriptor and sets the RXF bit in the SCCE—ASYNC HDLC 
register. The CRC error status condition is not checked on aborted frames. If the abort 
sequence is received and no frame is currently being received, the next buffer 
descriptor is opened and then closed with the AB bit set in the buffer descriptor. 


~ MOTOROLA MPC823 USER’S MANUAL 16-271 


Lil 

pan | 

ra 
50 
— 
to 
29 
= 
iri 
=o 
Soe 
ey-8 





ee 





yO 
oe 
Os 
mc 
n= 
$2 
=a 
fo Re 
oz 
on 

| ee 
m 





Communication Processor Module 


¢ CRC Error—Whern this error occurs, the channel writes the received cyclic redundancy 
check to the data buffer, closes the buffer, and sets the CR bit in the buffer descriptor 
and the RXF bit in the SCCE—ASYNC HDLC register. After receiving a signal unit wD 
this error, the receiver gets ready to receive the next frame. 


e Break Sequence Received Error—This error occurs when the UART receiver finds the 
first character of a break sequence. The channel closes the buffer by setting the RX 
BRK bit in the buffer descriptor and the RXF bit in the SCCE-ASYNC HDLC register. 
The CRC error status condition is not checked. The BRKSbit is set in the 
SCCE-ASYNC HDLC register when the first break of a sequence is found and the 
BRKE is set when an idle bit is received after a break sequence. 


16.9.19.12 PROGRAMMING THE SCC2 ASYNC HDLC CONTROLLER. 


16.9.19.12.1 SCC2 ASYNC HDLC Mode Register. When the SCC2 is in asynchronous 
HDLC mode, the 16-bit, memory-mapped, read/write protocol-specific mode register is 
referred to as the SCC2 ASYNC HDLC mode (PSMR-SCC2 ASYNC HDLC) register. It 
controls asynchronous HDLC mode-specific parameters. Since each protocol has specific 
icanements: the PSMR bits are different for each implementation. | 


PSMR-SCC2 ASYNC HDLC 










ae i 


RES CHLN RESERVED 
(IMMR & OxFFFFOO00) + 0xA28 a 


FLC—Flow Control 


O = Normal operation. 

-1= Asynchronous flow control. When the CTS pin is negated, the transmitter stops at 
the end of the current character. If CTS is negated past the middle of the current 
character, the next full character can be sent and transmission stops. When CTS 
is asserted once more, transmission continues where it left off and no CTS lost 
error is reported. No characters, except idles, are transmitted while CTS is 
negated. 7 









2/88 





Bits 1 and 4-15—Reserved 
These bits are reserved and should be set to 0. 


CHLN—Character Length 
For asynchronous HDLC and IrLAP modes, these bits must be set to 1. 
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16.9.19.12.2 SCC2 ASYNC HDLC Receive Buffer Descriptor. The SCC2 ASYNC HDLC 
controller uses the receive (RX) buffer descriptor to report information about each buffer’s 
received data. An example of the RX buffer descriptor process is illustrated in Figure 16-78. 
The first word of the RX buffer descriptor contains control and status bits. Bit 0 is set by the 
core when the buffer is available to the SCC2 ASYNC HDLC controller and it is cleared by 
the controller when the buffer is full. 










, RX DATA BUFFER POINTER 


NOTE: You are only responsible for initializing the items in bold. 






“TO Note: The communication processor module sets all the status bits in this buffer 

7 descriptor. You should clear all the status bits before submitting the buffer — 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 


E—Empty 

O= The data buffer associated with this buffer descriptor is filled with data or stops 
receiving because an error condition occurred. The core is free to examine or write 
to any fields of this RX buffer descriptor. The communication processor module 
does not use this buffer descriptor again as long as the E bit is zero. 

1 = The data buffer associated with this buffer descriptor is empty or currently receiving 
data. This RX buffer descriptor and its associated receive buffer are owned by the 
communication processor module. Once the E bit is set, the core should not write 
any fields of this RX buffer descriptor. 


Bits 1, 7, and 10—11—-Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Buffer Descriptor in Table) 

0 = This is not the last buffer descriptor in the RX buffer descriptor table. 

1 = This is the last buffer descriptor in the RX buffer descriptor table. After this buffer 
is used, the communication processor module receives incoming data into the first 
buffer descriptor that RBASE points to in the table. The number of RX buffer 
descriptors in this table are programmable and determined only by the W bit and 
overall space constraints of the dual-port RAM. . | 
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I—Interrupt 
O= The RXB bit in the SCCE—ASYNC HDLC register is not set after this buffer is used, 
~ but RXF operation is unaffected. 
1 = The RXB or RXF bit in the SCCE—ASYNC HDLC register is set when this buffer is 
used by the SCC2 ASYNC HDLC controller. 


|—Last in Frame 


This bit is set by the SCC2 ASYNC HDLC controller when this buffer is the last in a frame. 
If a closing flag or error is received, one or more of the BRK, CD, OV, and AB bits are set. 
The SCC2 ASYNC HDLC controller writes the number of frame octets to the DATA LENGTH 
field. 


0 = This buffer is not the last one in a frame. 
1= This buffer is the last one in a frame. 


F—First in Frame 
This bit is set by the SCC2 ASYNC HDLC controller when this buffer is the first in a frame. 


O= The buffer is not the first one in a frame. 
1 = The buffer is the first one in a frame. 


CM—Continuous Mode 


O = Normal operation. | 

1= The E bit is not cleared by the communication processor module after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
overwritten next time the buffer descriptor is accessed by the communication 
processor module. However, the E bit is cleared if an error other than CRC occurs 
during Feceptlon, regardless of how the CM bit is set. 


BRK—Break Character Received | 
This bit indicates that the current frame is closed when a break character is received. 


BOF—Beginning of Frame Encountered 


This bit indicates that the current frame is closed when a BOF character is received instead 
of the expected EOF. 


AB—RX Abort Sequence 


This bit indicates that an asynchronous HDLC abort sequence or framing error is received 
to terminate this frame. | 


CR—RX CRC Error 


This bit indicates that this frame contains a CRC error. The received CRC bytes are always 
written to the receive buffer. 


OV—Overrun 
This bit indicates that a receiver overrun has occurred during frame reception. 
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CD—Carrier Detect Lost 
This bit indicates that the carrier detect signal is negated during frame reception. 


DATA LENGTH 

These bits represent the number of octets the communication processor module writes into 
this buffer descriptor data buffer once the buffer descriptor is closed. When this buffer 
descriptor is the last one in the frame, DATA LENGTH contains the total number of frame 
octets. The actual amount of memory allocated for this buffer should be greater than or 
equal to the contents of the MRBLR. 


“Oo Note: If the received frame has a length that is an exact multiple of the MRBLR, the 

| buffer descriptor with the L bit set does not actually have any characters in it and 
tne DATA LENGTH field contains a value equal to the sum of the DATA 
LENGTH fields of the other buffer descriptors in the frame. 


RX DATA BUFFER POINTER 


These bits always point to the first location of the associated data buffer and can reside in 
internal or external memory. 


16.9.19.12.3 SCC2 ASYNC HDLC Transmit Buffer Descriptor. Data is sent to the SCC2 
ASYNC HDLC controller for transmission on an SCC2 channel by arranging it in buffers . 
referenced by the channel transmit (TX) buffer descriptor table. Using the buffer descriptors, 
the SCC2 ASYNC HDLC controller confirms transmission or indicates error conditions so 
that the core will know the buffers have been serviced. 





mT Sapeanonnan Dntansnecineaaeenn roses Oe ceca pete on Bieter 


fa [res[w [i [eff] scr 


, TX DATA BUFFER POINTER 


NOTE: You are only responsible for initializing the items in bold. 










ey Note: The communication processor module sets all the status bits in this buffer 

aa descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 


MOTOROLA MPC823 USER’S MANUAL 16-275 





uw 
| 
= d 
ator 
— 
£9 
a 
> th 
=O 
Sof 
Oo 


an | 
if 


Sa 








3g 
or 
Oz 
Mme 
a= 
roKe) 
ee 
== 
oS 
Oo 
| re 
| 
m 





Communication Processor Module 


R—Ready 


0 = The data buffer associated with this buffer descriptor is not ready for transmission. 
You are free to manipulate this buffer descriptor or its associated data buffer. The 
communication processor module clears this bit after the buffer is transmitted or 

_ after an error condition is encountered. 

1 = The data buffer, which you have prepared for transmission, is not transmitted yet 
or is currently being transmitted. You cannot write any fields of this buffer descriptor 
once this bit is set. 


Bits 1, 5, and 7-11—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Buffer Descriptor in Table) 


0 = This is not the last buffer descriptor in the TX buffer descriptor table. 

1 = This is the last buffer descriptor in the TX buffer descriptor table. After this buffer is 
used, the communication processor module receives incoming data into the first 
buffer descriptor that TBASE points to in the table. The number of TX buffer 
descriptors in this table are programmable and determined only by the W bit and 
overall space constraints of the dual-port RAM. 


I—Interrupt 


O= The TXB bit in the SCCE—ASYNC HDLC register is not set after this buffer is used. 
1= The TXB bit in the SCCE—ASYNC HDLC register is set when this buffer is 
transmitted by the SCC2 ASYNC HDLC controller. 


|—Last 


O= This is not the last buffer in the current frame. 
1= This is the last buffer in the current frame. The proper CRC and closing FLAG are 
transmitted after the last byte is transmitted. | 


CM—Continuous Mode 


O = Normal operation. 

1 = The R bit is not cleared by the communication processor module after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
retransmitted the next time the communication processor module accesses this 
buffer descriptor. However, the R bit is cleared if an error occurs during 
transmission, regardless of how the CM bit is set. 


CT—CTS Lost 


In NMSI mode, this bit indicates that CTS is lost during frame transmission. If data from more 
than one buffer is currently in the FIFO when this error occurs, this bit is set in the currently 
open TX buffer descriptor. These bits are written by the SCC2 ASYNC HDLC controller after 
it finishes transmitting the associated data buffer. 
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DATA LENGTH 


These bits represent the number of bytes the SCC2 ASYNC HDLC controller should 
transmit from this buffer descriptor data buffer. It is never modified by the communication 
processor module. The value of this field must be greater than zero. These bits are written 
by the SCC2 ASYNC HDLC controller after it finishes transmitting the associated data 
buffer. 


TX DATA BUFFER POINTER 

These bits contain the address of the associated data buffer, can be even or odd, and can 
reside in internal or external memory. This value is never modified by the communication 
processor module. These bits are written by the SCC2 ASYNC HDLC controller after it 
finishes transmitting the associated data buffer. 


16.9.19.12.4 SCC2 ASYNC HDLC Event Register. When the SCC2 is in asynchronous 
HDLC mode, the 16-bit memory-mapped SCC2 event register is referred to as the SCC2 
asynchronous HDLC event (GCCE—-ASYNC HDLC) register. Since each protocol has 
specific requirements, the SCCE bits are different for each implementation. This register is 
used to generate interrupts and report events recognized by the SCC2 ASYNC HDLC . | 
channel. When an event is recognized, the SCC2 ASYNC HDLC controller sets the 
corresponding bit in the SCCE—ASYNC HDLC register. Interrupts generated by this register 
can be masked by the SCCM—ASYNC HDLC register. 


A bit is cleared by writing a 1 (writing a zero has no effect) and more than one bit can be 
cleared at a time. However, all unmasked bits must be cleared before the communication 
processor module clears the internal interrupt request. This register is cleared at reset and 
can be read at any time. 


SCCE-ASYNC HDLC 


geanien SSRcrOn Ru = 
ee 


RESERVED feu GLt RESERVED RES | BRKE | BRKS | TXE 
(IMMR & OxFFFFO000) + 0xA30 


Bits 0-2, 5-6, and 8—Heserved | 
These bits are reserved and should be set to O. 



















GLR—Glitch on RX 


This bit indicates that the serial communication controller has found a glitch on the receive 
clock. 


GLT—Glitch on TX 


This bit indicates that the serial communication controller has found a glitch on the transmit 
clock. 
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IDL—Idle Sequence Status Changed 


This bit indicates that a change in the status of the serial line has occurred. The real-time 
status of the line can be read in the SCCS—ASYNC HDLC register. | 7 


TXE—TX Error , 
This bit indicates that an error has occurred on the transmitter aenack 


BRKe—Break End 


This bit indicates that the end of a break sequence has been found. This indication | is set 
when one idle bit is recelved after a break sequence. 


BRKS—Break Start 


This bit indicates that a break character has been received. This is the first break of a hedan 
sequence. You will not receive multiple BRKS events if a long break sequence is detected. 


RXF—RX Frame 


This bit indicates that the SCC2 ASYNC HDLC channel has received a spiniplete frame. This 
bit is set no sooner than two bit times after the last bit of the closing flag is received. 


BSY—Busy Condition 3 
This bit indicates that a frame has been received and discarded due to a lack of buffers. 


TXB—Transmit Buffer — | | 

This bit indicates that a buffer with its | bit set has been transmitted on the SCC2 ASYNC 
HDLC channel. This bit is set no sooner than when the last bit of the closing flag begins its 
transmission if the buffer is the last one in the frame. Otherwise, this bit is set after the last 
byte of the buffer is written to the transmit FIFO. 


-RXB—RX Buffer 


This bit indicates that a buffer, that i is not the last in the frame with its | bit set, has been 
received over the SCC2 ASYNC HDLC channel. | 
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16.9.19.12.5 Differences Between HDLC and ASYNC HDLC. There are four basic 
differences in the way the HDLC and ASYNC HDLC modes operate and they are as follows: 


e There is no maximum received frame length counter in the ASYNC HDLC controller. | 
Therefore, the controller receives all characters between opening and closing flags and , 
there is no way to stop the controller from writing to memory. This in no way affects the 
number of bytes received into a specific buffer descriptor. It just means that a frame is 
received into memory in its entirety. 


e lf an error causes a frame to stop being received, the character being received at the ~ 
moment the error occurred is not written into memory. For example, if a CD lost error ae 
occurred, the frame is closed and the partial character is not written to memory. Thus, | S 
the octet count only reflects the number of bytes written to memory. ae 


e The automatic error counters in HDLC mode have not been implemented in 
asynchronous HDLC mode. 


e Noisy characters (those whose three samples are not the same) are not accounted for 
in the ASYNC HDLC controller. It is assumed that the CRC catches any data integrity 
problems. : 


Dy 4 Note: The GRACEFUL STOP TRANSMIT command is not supported by the ASYNC. 
; HDLC controller. 


16.9.19.12.6 SCC2 ASYNC HDLC Programming Guide. The following is an initialization 
sequence guide for the SCC2 in asynchronous HDLC mode. 

Initialize the SDCR. 

In NMSI mode, configure the port A pins to enable RXD2 and TXD2. 

Configure a baud rate generator to generate appropriate channel clocking frequency. 


hop = 


Program the SICR to route the baud rate generator clocking to the serial 
communication controller, which is running asynchronous HDLC. 


5. Select whether the channel is using the time-slot assigner or the NMSI pins in the 
SICR. 


6. Write RBASE and TBASE in the SCC2 parameter RAM to point to the first RX buffer 
descriptor and TX buffer descriptor. 


7. Issue the INIT RX AND TX PARAMS command for the serial communication 
controller. 


8. Program the RFCR and TFCR. 

9. Write the MRBLR with the maximum receiver buffer size. 
10.Write C_MASK and C_PRES with the standard values. 
11.Write the ZERO register to Ox0000. 


12.Program the RFTHR to the number of frames that should be received before an 
interrupt is generated. 
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13.Program the TX and RX control character tables. 

14. Initialize all RX buffer descriptors. | 

15. Initialize all TX buffer descriptors. 

16. Clear the SCCE—ASYNC HDLC register by writing OxFFFF to it. 


17. Program the SCCM-ASYNC HDLC register with the proper mask to allow all sicierre 
interrupts. 


18.Program the GSMR_H register. 


so 19.Program the GSMR_L feOetens to asynchronous HDLC mode, but do not turn on the 
3 | transmitter or receiver. : 


——" 20. Set the PSMR-SCC2 ASYNC HDLC appropriately. 


21.Turn on the transmitter and receiver in the GSMR_L register by setting the ENT and 
ENR bits. 


16.9.20 The SCC2 in IrDA Mode 


IrDA is a family of specifications intended to facilitate the interconnection of computers and 
peripherals using a directed half duplex serial infrared physical communications medium. 
The infra-red data association (IrDA) physical layer standard version 1.1 specifies three 
modes of operation, each one with a distinct modulation scheme and signaling rate. 


e Low speed—2.4Kb/s to 115.2Kb/s 


e Middle soeed—0.576Mb/s or 1.152Mb/s. 
° > High speed—4Mb/s 


IROUT 


i IR aml | : OUTPUT q 
DRIVER&LED 


ENCODER 


IR 
TRANSDUCER 
MODULE 


DETECTOR IRIN 
- & RECEIVER 


MPC823 





Figure 16-91. Serial IrDA Link 
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16.9.20.1 LOW-SPEED IRDA PROTOCOL. The low-speed IrDA protocol consists of a 
data link layer and a physical layer. 


e The data link layer is based on a preexisting ASYNC HDLC protocol standard. See 
Section 16.9.19 The SCC2 in Asynchronous HDLC Mode for more details. OxCO is 
used as a Start flag and OxC1 is used as an end flag. Each character is compromised 
out of a start bit, 8 data bits, no parity bit and ending with a stop bit, as shown in 
Figure 16-92. 


e The physical layer defines the electrical parameters of the signals between the 
encoder/decoder module and the infra-red transducer module. The signal waveform is 
shown in Figure 16-92. For all signaling rates up to and including 115.2Kb/s, the 
minimum pulse duration is the same—*/,, of the bit duration for the 115.2Kb/s signal 
(minus a protocol-defined tolerance). The maximum pulse duration is 3/,, of the bit 
duration (plus a protocol-defined tolerance). 


UART FRAME 


DATA BITS 





3/16 BIT TIME 


Figure 16-92. Low-Speed IrDA Data Format 
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16.9.20.2 MIDDLE-SPEED IRDA PROTOCOL. The middle-speed IrDA protocol consists 
of a data link layer and a physical layer. 4 


e The data link layer is derived from the preexisting synchronous HDLC protocol 

- gtandard. The frame format follows the standard HDLC format except that it requires 
two start flags. The frame consists of two start flags, an address field, a control field, an 
information field, a frame check sequence field and minimum of one ending flag. Ox7E 
is used for the start flag as well for the end flag. : 


a . 


Bo START FLAG | STARTFLAG| ADDRESS | CONTROL | INFORMATIO END FLAG 


Figure 16-93. Middle Speed Packet Format 


CII 














e The physical layer defines the electrical parameters of the signals between the 
encoder/decoder module and the infra-red transducer module. The signal waveform is 
shown in Figure 16-94. For 0.576 and 1.152Mb/s, the minimum and maximum pulse 
duration are the nominal '/, of the bit duration (plus or minus the protocol-defined 
tolerance). | 


DATA BITS 





(A) 


—e -<t—__ 1/4 BIT TIME 


Figure 16-94. Middle-Speed IrDA Data Format 
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16.9.20.3 HIGH-SPEED IRDA PROTOCOL. The high-speed IrDA protocol is derived from 
the preexisting SCC2 Transparent protocol standard. 


16.9.20.3.1 4PPM Data Encoding. Pulse position modulation (PPM) encoding is achieved 
by defining a data symbol duration (Dt) and subsequently subdividing Dt into a set of equal 
time slices called “chips”. In PPM schemes, each chip position within a data symbol 
represents one of the possible bit combinations. Each chip has a duration of Ct given by 
Ct = Dt/Base. 


In this formula base refers to the number of pulse positions or chips in each data symbol. 
The base for high-speed IrDA protocol is defined as four and the resulting modulation 
scheme is four-pulse position modulation (4PPM). The data rates of alrDA PPM system are 
defined as 4.0Mb/s. 


The resulting values for Ct and Dt are as follows: 


e Dt=500 ns 
° Ct=125ns 


The figure below illustrates a data symbol field and its enclosed chip durations for a 4PPM 
scheme. 


CHIP 1 CHIP2 CHIPS CHIP4 


Figure 16-95. One Complete Symbol 


Because there are four unique chip positions within each symbol in 4PPM, four independent 
symbols exist in which only one chip is logically a “one” while other chips are logically a 
“zero”. These four unique symbols are the only legal data symbols (DD) allowed in 4PPM. 
Each data symbol represents two bits of payload data, or a single data bit pair (DBP), so that 
a byte of payload data can be represented by four data symbols in sequence. The following 
table defines the chip pattern representation of the four unique data symbols defined for 
4PPM. | 


DATA BIT PAIR 4PPM DATA SYMBOL 
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Logical “1” represents a chip duration when the transmitting LED is emitting light, while 
logical “O” represents a chip duration when the LED is off. Data encoding for transmission is 
done LSB first. The 4PPM data encoding defines only the legal encoded payload data 
symbols. All other 4-chip combinations are by definition illegal symbols for encoded payload 
data. Some of these illegal symbols are used in the definition of the packet envelope 
(preamble, start flag, stop flag) because they are unambiguously not data. 


16.9.20.3.2 Data Link Layer. The data link layer protocol defines the following packet 
format. 


LINK LAYER 


Figure 16-96. High-Speed Packet Format 


The preamble (PA) field is used by the receiver to establish bit synchronization. The PA field 
consists of exactly sixteen repeated transmissions of the following stream of symbols. 


Figure 16-97. Preamble Field Symbol Format 


On the receive side, the PA field does not need to be valid in the received packet. After the 
PA field, the receiver starts searching for the start flag (STA) to establish symbol 
synchronization. After the start flag is received, the receiver can begin interpreting the data 
symbols in the link layer frame. The start flag consists of exactly one transmission of the 


following stream of symbols. 


0000 1100 0000 P4100 | 0110 0000 0110 0000 


Figure 16-98. Start Flag Symbol Format 
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The link layer frame generally consists of the address, control, data and CRC32 fields. The 
IrDA transmitter decodes the packet bits into 4PPM format. The 4PPM encoding will be 
described later. The receiver is responsible to decode the incoming data frame into the 
regular bit format and to deliver it to the software. The receiver continues to receive and 
interpret data until the stop flag (STO) is recognized. A stop flag indicates the end of frame. 
The stop flag consists of exactly one transmission of the following stream of symbols. 


0000 1100 0000 1100 0000 1100 0000 1100 


Figure 16-99. Stop Flag Symbol Format ( 





The physical layer defines the electrical parameters of the signals between the 
encoder/decoder module and the IR transducer module. All frame envelope patterns—PA, 
STA, and STO—are transmitted as is. The link layer frame bits are encoded before 
transmission. Each two bits encoded into four chips according to the 4PPM scheme. 


DATA BITS 


1/4 BIT TIME 


Figure 16-100. High-Speed IrDA Data Format 
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16.9.20.4 SERIAL INFRA-RED INTERACTION PULSES. To guarantee nondisruptive 
coexistence with slower (a maximum of 115.2Kb/s) systems, once a high-speed (above 
115.2Kb/s) connection has been established the high-speed system must emit a Serial 
infra-red interaction pulse (SIP) at least once every 500ms. This continues for the duration 
of the connection to quiet slower systems that might interfere with the link. The pulse is 
illustrated in Figure 16-101. 


| “ 


(B) 





Figure 16-101. Serial Infra-Red Interaction Pulse Waveform 


The serial infra-red interaction pulse can be generated in two ways: 


e By the software when you set the GS bit in IRSIP register. 
e By the Timer 2 expiration when you set the TS bit in the IRSIP register. 


You are responsible for creating the appropriate SIP waveform by writing the proper values 
to the SLL and SHL fields of the IRSIP register. 
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16.9.20.5 PROGRAMMING MODEL. 


16.9.20.5.1 SCC2 Infra-Red Mode Register. The SCC2 serial infra-red mode (IRMODE) 
register controls the infra-red operation mode (low-, middle-, or high speed), the number of 
preambles, the loop mode, the full-duplex operation, and the DPLL clock rate.. 


IRMODE 





_ (IMMR & OxFFF0000) + 0xA38 


PA—Number of Preambles : 7 —_ ; es 
This field determines the number of preambles in a high-speed transmitter.. It is valid only in 
high-speed mode. | : , | | 


0000 = 16 preambles. 
0001 = 1 preamble. 


1111 = 15 preambles. © 
RXP—RX Polarity _ 


This bit determines the polarity of the received signal. 
0= Active high polarity. An active high pulse is decoded as 0. 
1 = Active low polarity. An active low pulse is decoded as 0. 


TXP—TX Polarity 
This bit determines the polarity of the transmitted signal. 


0= Active high polarity. An active high pulse is encoded as 0. 
1 = Active low polarity. An active low pulse is encoded as 0. - 


DCR—IrDA DPLL Clock Ratio 


This field determines the clock ratio between the IrDA DPLL clock and the bit rate clock. This 
field is valid only in high-speed mode. as | 


00 = 12x bit rate clock. 
O01 = Reserved. 
1x = Reserved. 
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FD—Full Duplex 


0 = Data reception is disabled during the transmission process. 
1 = Transmission and reception of data in parallel are enabled. 


LOOP—Loop Mode 


When set, this bit selects the local loopback operation. The transmitter output is internally 
connected to the receiver input. The receiver and transmitter operate normally, except that 
the received data is ignored. 


O = Normal operation. 
1 = The IrDA is in loopback mode. 


Note: The FD bit should be set in loopback mode. 





M —Infra-Red Mode 
Mode of operation. 


00 = Low-speed mode (up to and including 115.2kb/s). 
01 = Middle-speed (0.576Mb/s or 1.152Mb/s). 

10 = High-speed (4.0Mb/s). 

11 = Reserved. 


EN—Enable IrDA 
This bit enables IrDA decoder/encoder operation. 


O = IrDA Is disabled. 
1 = IrDA is enabled. 


7 4 Note: Changing the EN bit value is allowed only when the SCC2 is off (after the ENR 
and ENT bits in the GSMR_L are cleared). 
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16.9.20.5.2 SCC2 Infra-Red Serial Interaction Pulse Control Register. The SCC2 


infra-red serial interaction pulse control (IRSIP) register controls the initiation of the serial 
infrared interaction pulse. 


IRSIP 


SHL 





(IMMR & OxFFF0000) + 0xA3A ei 


GS—Generate Serial Infra-Red Interaction Pulse 


0 = Writing zero to this bit has no effect. 
1 = Setting this bit generates a serial infra-red interaction pulse, which occurs only 
when the channel is idle. This bit is immediately reset by the IrDA controller. 


7 wr Note: Reading the GS bit always returns a zero. 


TS—Timer Set 


O= The Timer 2 status has no effect on the serial infra-red interaction pulse. 
1 = The expiration of Timer 2 triggers the generation of a serial infra-red interaction 
pulse. 


SHL—Serial Infra-Red Interaction Pulse High-Level Length — 
Program this field with the width of the SIP assertion part (in bit rate clock units). 


SLL—Serial Infra-Red Interaction Pulse Low-Level Length 
Program this field with the width of the SIP negation part (in bit rate clock units). 
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16.9.20.5.3 Low-Speed IrDA Programming Guide. Low-speed infra-red programming is 
very similar to SCC2 ASYNC HDLC programming. The only difference is the value of EOF 
and BOF in the SCC2 parameter RAM and the programming of the IRMODE register. Use 
the following initialization sequence for low-speed infra-red. 


1. Initialize the SDCR with the appropriate arbitration ID. 


2. Configure the port A and port C pins to enable RXD2 and TXD2. This assumes you 
are using NMSI mode. If not, appropriately configure the time-slot assigner and pins. 


3. Configure a baud rate generator to generate the appropriate channel clocking | 
frequency. 


4. Program the SICR to route the baud rate generator clocking to the serial 
communication controller running SCC2 ASYNC-HDLC. 


5. Select whether the channel is using the time-slot assigner or the NMSI pins in the 
SICR. 


6. Write RBASE and TBASE in the SCC2 parameter RAM to point to the first RX buffer 
descriptor and the first TX buffer descriptor. 


7. Issue the INIT RX AND TX PARAMS command to the serial communication controller. 
8. Program RFCR and TFCR. 

9. Write MRBLR with the maximum receive buffer size. 

10.Write C_MASK and C_PRES with the standard values. 

11.Write OxCO to BOF, 0xC1 to EOF and 0x7D to ESC. 

12.Write 0 to the ZERO register in the parameter RAM. 


13.Program the RFTHR to the number of frames that should be received before an 
interrupt is generated. 





14. Program the TX and RX control character tables. 

15. Initialize all RX buffer descriptors. 

16. Initialize all TX buffer descriptors. | 
17.Clear the SCCE-ASYNC HDLC register by writing OxFFFF to it. 


—18.Program the SCCM-—ASYNC HDLC register with the proper mask to allow all desired 
interrupts. 


19.Program the GSMR_H. 


20.Program the MODE field of the GSMR_L to SCC2 ASYNC HDLC mode, but do not 
turn on the transmitter or receiver. 


21.Write 0x0001 to the IRMODE register to enable low-speed infra-red. 
22.Set the PSMR_SCC2 ASYNC HDLC appropriately. 
23. Turn on the transmitter and receiver in the GSMR_L by setting the ENT and ENR bits. 
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16.9.20.5.4 Middle-Speed IrDA Programming Example. Middle-speed infra-red 

programming is very similar to SCC2 synchronous HDLC programming. The parameter 

RAM programming and the RX and TX buffer descriptors are the same as in the SCC2 

HDLC. All of the SCC2 synchronous registers and the infra-red registers must be initialized. | 
The following list is an initialization sequence for a middle-speed infra-red channel assuming 

that an external clock is provided. The CLK3 pin is used for the infra-red receiver and 

transmitter. 


1. Configure the port A pins to enable the TXD2 and RXD2 pins. Write PAPAR bits 13 
and 12 with ones. Write PADIR bits 13 and 12 with zeros. Write PAODR bits 13 and — 
12 with zeros. ae 


2. Configure port A to enable the CLK3 pin. Write PAPAR bit 5 with a one. Write PADIR eee 
bit 5 with a zero. 


3. Connect the CLKS pin to the SCC2 using the serial interface. Write the R2CS field in 
SICR to 110. Write the T2CS bits in the SICR to 110. 


4. Connect the SCC2 to the NMSI (its own set of pins). Clear the SC2 bit in the SICR. 
5. Write the SDCR with the appropriate arbitration ID. 


6. Write RBASE and TBASE in the SCC2 parameter RAM to point to the RX buffer 
descriptor and TX buffer descriptor in the dual-port RAM. Assuming one RX buffer 
descriptor at the beginning of dual-port RAM and one TX buffer descriptor following 
that RX buffer descriptor, write RBASE with 0x2000 and TBASE with 0x2008. | 


7. Program the CPCR to execute the INIT RX AND TX PARAMS command for the serial 
communication controller. 


8. Write RFCR with 0x18 and TFCR with 0x18 for normal operation. 


9. Write MRBLR with the maximum number of bytes per receive buffer. For this case, 
assume 256 bytes, so MRBLR = 0x0100. The value 256 was chosen to allow an entire 
receive frame to fit into one receive buffer. 


10. Write CRC_P with OxFFFFFFFF to comply with 16-bit CRC32. 

11.Write CRC_C with OxDEBB20E3 to comply with 16-bit CRC32. 

12.Clear DISFC, CRCEC, ABTSC, NMARC, and RETRC for the sake of clarity. 
13.Write MFLR with 0x0100 to make the maximum frame size 256 bytes. 
14.Write RFTHR with 0x0001 to allow interrupts after each frame. 

15.Write HMASK with 0x0000 to allow all addresses to be recognized. 
16.Clear HADDR1, HADDR2, HADDR3, and HADDR4 for clarity. 


17. Initialize the RX buffer descriptor. Assume the RX data buffer is at 0x00001000 in main 
memory. Write OxBOO0 to RX_BD_Status. Write Ox0000 to RX_BD_Length (not 
required-done for instructional purposes only). Write 0x00001000 to RX_BD_Pointer. 


18. Initialize the TX buffer descriptor. Assume the TX data frame is at Ox00002000 in main 
memory and contains five 8-bit characters. Write OxBCOO to TX_BD_Status. Write 
0x0005 to TX_BD_Length. Write 0x00002000 to TX_BD_Pointer. 


19.Write OxFFFF to the SCCE—HDLC to clear any previous events. 
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20.Write 0x001A to the SCCM—HDLC to enable the TXE, RXF, and TXB interrupts. 


21.Write Ox20000000 to the CIMR to allow the SCC2 to genial a system interrupt. The 
CICR should also be initialized. 


22.Write Ox00000000 to the MODE field of the GSMR_H to enable normal behavior of the 
CTS and CD pins and idles between frames (as opposed to flags). 


23.Write 0x00028800 to the MODE field of the GSMR_L to configure the CTS and CD 
pins to automatically control transmission, reception (DIAG field), and HDLC mode. 
Normal operation of the transmit clock is selected and the TCI bit is cleared. The 
TDCR and the RDCR must be configured to 16x clock mode and the receiver decoding 
method must be NRZI. Notice that the transmitter (ENT) and receiver (ENR) have not 
been enabled. If you want inverted infra-red operation, set the RINV and TINV bits in 
the GSMR_L. 


24. Set the PSMR-HDLC to 0x1000 to configure two opening and one closing flag, 16-bit 
CCITT-CRC, and prevention of multiple frames in the FIFO. 


25.Write 0x0108 for a 1.152Mb/s infra-red rate or Ox0084 for a 0.576Mb/s infra-red rate 
to the IRSIP register. When working with Timer 2 as the SIP trigger, the values should 
be 0x2108 for a 1.153Mb/s infra-red or 0x2084 for a 0.572Mb/s. 


26. Write 0x0003 to the IRMODE register to enable the infra-red and to set the mode of 
operation to middle-speed. 


27. Program the TMR2 register when working with Timer 2 as the SIP trigger. 


28.Write 0x00028830 to GSMR_L to enable the SCC2 transmitter and receiver. This 
additional write ensures that the ENT and ENR bits will be enabled last. 





7 Note: After 5 bytes and CRC have been transmitted, the TX buffer descriptor is 
automatically closed. Once a complete frame is received, the RX buffer 
descriptor is closed. Any data received after 256 bytes or a single frame causes 
a busy (out-of-buffers) condition since only one RX buffer descriptor is prepared. 
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16.9.20.5.5 High-Speed IrDA Programming Example. High-speed infra-red 
programming Is very similar to SCC2 Transparent programming. The parameter RAM 
programming and the RX buffer descriptor and TX buffer descriptor are the same as in the 
SCC2 transparent mode, which is described in Section 16.9.21 The SCC2 in Transparent 
Mode. The SCC2 and infra-red registers must be initialized. The following list is an — 
initialization sequence for a high-speed infra-red channel. The transmitter and receiver are 
both enabled. Both transmit and receive clocks are provided externally to MPC823 using the 
CLK3 pin. 


1. 


Configure the port A pins to enable the TXD2 and RXD2 pins. Write PAPAR bits 13 
and 12 with ones. Write PADIR bits 13 and 12 with Zeros. Write PAODR bits 13 and 
12 with zeros. 


. Configure port A to enable the CLK3 siti Write PAPAR bit 5 with a one. Write PADIR 


bit 5 witha zero. 


. Connect the CLK3 pin to SCC2 using the serial interface. Write the R2CS field in the 


SICR to 110. Write the T2CS field in the SICR to 110. 


. Connect the SCC2 to the NMSI (its own set of pins). Clear the SC2 bit in the SICR. 
. Write the SDCR with the appropriate arbitration ID. 
. Write RBASE and TBASE in the SCC2 parameter. RAM to point to the RX buffer 


descriptor and TX buffer descriptor in the dual-port RAM. Assuming one RX buffer 
descriptor at the beginning of dual-port RAM, and one TX buffer descriptor following 
that RX buffer descriptor, write RBASE with 0x2000 and TBASE with 0x2008. 


. Program the CPCR to execute the INIT RX AND TX PARAMS command for the serial 


communication controller. 


8. Write RFCR with 0x18 and TFCR with 0x18 for normal apataiion: 


. Write MRBLR with the maximum number of bytes De receive buffer. For this case, 


assume 16 bytes, so MRBLR = 0x0010. 


10.Write OxFFFFFFFF to CRC_P for 32-bit CRC-CCITT (CRC32). For ee see 


Section 16.9.21.5 SCC2 Transparent Parameter RAM Memory Map. 


11.Write OxDEBB20E3 to CRC_C for 32-bit CRC-CCITT (CRC32). 
12. Initialize the RX buffer descriptor. Assume the RX data buffer is at Ox00001000 in main 


memory. Write OxBOOO to RX_BD_Status. Write 0x0000 to RX_BD_Length (not 
required because it is only done for uneuucuenel purposes). Write 0x00001000 to | 
RX_BD_Pointer. 


13. Initialize the TX buffer descriptor. Assume the TX data butfer is at 0x00002000 in main 


memory and contains five 8-bit characters. Write OxBCOO to TX_BD_Status. Write 
0x0005 to TX_BD_Length. Write 0x00002000 to TX_BD_Pointer. 


14. Write OxFFFF to the SCCE-Transparent to clear any previous events. 
15. Write 0x0013 to the SCCM—Transparent to enable the TXE, TX, and RX interrupts. 
16.Write 0x20000000 to the CIMR to allow SCC2 to care a system mtermepre The 


CICR should also be initialized. 
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17.Write 0x00009980 to the GSMF_H to configure the transparent channel. The CDS 
and CTSS bits must be set to one. The TDCR, RDCR, RENC, and TENC fields must 
be set to zero. 


18. Write Ox00000000 to the GSMR_L. Normal operation of the transmit clock is used (TCI 
bit is cleared). Notice that the transmitter (ENT) and receiver (ENR) have not been 
enabled yet. 

19. Write 0x031c to the IRSIP register. When working with Timer 2 as the SIP trigger, the 
value should be 0x231c. 


20.Write 0x0005 to the IRMODE register to enable the infra-red and to set the mode of 
operation to high speed. 


21.Program TMR2 register when working with Timer 2 as the SIP trigger. 


22. Write 0x00000030 to the GSMR_L to enable the SCC2 transmitter and receiver. This 
additional write ensures that the ENT and ENR bits will be enabled last. 


Note: After 5 bytes have been transmitted, the TX buffer descriptor is automatically 
closed. Once a complete frame is received, the RX buffer descriptor is closed. 
Any data received after 16 bytes or a single frame causes a busy (out-of-buffers) 
condition since only one RX buffer descriptor is prepared. 





16.9.21 The SCC2 in Transparent Mode 


The SCC2 in Transparent mode allows serial data to be transmitted and received over the 
serial communication controller without any modification to the datastream. Transparent 
mode provides a clear channel on which the serial communication controller does not 
perform bit-level manipulation. Any protocol that uses the transparent mode must have a 
software layer that loads the parameters. SCC2 in Transparent mode functions as a 
high-speed serial-to-parallel and parallel-to-serial converter. This mode is also referred to 
as a totally transparent or promiscuous operation. | 


There are several basic applications for transparent mode. First, some data needs to be 
moved serially, but requires no superimposed protocol. Second, some board-level 
applications require a serial-to-parallel and parallel-to-serial conversion that allows 
communication between chips on the same board. Third, some applications require the data 
to be switched without interfering with the protocol encoding itself. For instance, in a 
multiplexer, data from a high-speed time-multiplexed serial stream is multiplexed into 
multiple low-speed datastreams. The objective is to switch the data path without altering the 
protocol encoded on that data path. 


By appropriately setting the GSMR_L, the SCC2 channels can be configured to function in 
Transparent mode. The MPC823 receives and transmits the entire serial bitstream 
transparently. This mode is configured by selecting the TTX and TRX bits in the GSMR_H 
for the transmitter and receiver, respectively. However, both bits must be set for full-duplex 
transparent operation. 
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If just one of the TTX or TRX bits is set, the other half of the serial communication controller 
operates with another protocol as programmed in the MODE field of the GSMR_L. This 
allows loopback modes to DMA data from one memory location to another while converting 
the data to a specific serial format. The SCC2 in Transparent mode can work with the 
time-slot assigner or nonmultiplexed serial interface and support modem lines with the 
general-purpose !/O pins. The data can be transmitted and received with the MSB or LSB 
first in each octet. 


The SCC2 in Transparent mode consists of separate transmit and receive sections whose 
operations are asynchronous with the core. Each clock can be supplied from the internal 
baud rate generator bank, DPLL output, or external pins. 


16.9.21.1 FEATURES. The following list summarizes the main features of the SCC2 in 
Transparent mode: 


e Flexible data buffers 

e Automatic Sync detection on reception 

¢ CRCs can be transmitted and received 

e Reverse data mode 

° Another protocol can be performed on the other half of the SCC2 in Transparent mode 


16.9.21.2 SCC2 TRANSPARENT CHANNEL FRAME TRANSMISSION PROCESS. The 
transparent transmitter is designed to work with almost no intervention from the core and 
when the core enables the SCC2 transmitter in transparent mode, it starts transmitting idles. 
The serial communication controller polls the first buffer descriptor in the channel’s transmit 
(TX) buffer descriptor table. When there is a message to transmit, the serial communication 
controller fetches the data from memory, loads the transmit FIFO, and waits for transmitter 
synchronization before transmitting the message. 


Transmitter synchronization can be achieved with the CTS pin or by waiting for the receiver 
to achieve synchronization, depending on how the TXSY bit is set in the GSMR_H. Once 
transmitter synchronization is achieved, transmission begins. 


When buffer descriptor data has been completely transmitted, the L bit is checked and if it 
is set, the serial communication controller writes the message status bits into the buffer 
descriptor and clears the R bit. It then starts transmitting idles until the next buffer descriptor 
is ready and if it is ready some idles are still transmitted. The transmitter only begins 
transmission again after it achieves synchronization. When the end of the current buffer 
descriptor has been reached and the L bit is cleared, only the R bit is cleared and the 
transmitter moves immediately to the next buffer to begin transmission with no gap on the 
serial line between buffers. Failure to provide the next buffer in time results in a transmit 
underrun, thus causing the TXE bit in the SCCE-—Transparent register to be set. 
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In both cases, an interrupt is issued according to the | bit in the buffer descriptor. By 

appropriately setting the | bit in each buffer descriptor, interrupts are generated after each 
buffer or group of buffers is transmitted. The serial communication controller then proceeds 
to the next buffer descriptor in the table and any whole number of bytes can be transmitted. 


Ifthe REVD bit in the GSMR_-H is set, each data byte is reversed in its bit order before being 
transmitted and the most-significant bit of each octet is transmitted first. 


You can decrease the latency of the transmitter by decreasing the transmit FIFO size. This 
option is enabled by the TFL bit in the GSMR_H and causes transmitter underruns at higher 
transmission speeds. An optional CRC can be appended to each transparent frame if it is 
enabled in the TX buffer descriptor. The CRC pattern is chosen in the TCRC field of the 
GSMR_H. 


16.9.21.3 SCC2 TRANSPARENT CHANNEL FRAME RECEPTION PROCESS. When 
the core enables the SCC2 receiver in transparent mode, it waits to achieve synchronization 
before data is received. The receiver can be synchronized to the data by a synchronization 
pulse or Sync pattern. 


_ After a buffer is filled, the serial communication controller clears the E bit in the buffer 


descriptor and generates an interrupt if the I bit in the buffer descriptor is set. It then moves 
to the next RX buffer descriptor in the table and begins moving data to its associated buffer. 
If the next buffer is not available as needed, the BSY bit in the SCCE-—Transparent register 
signifies a busy signal that can generate a maskable interrupt. The receiver reverts to hunt 
mode when the ENTER HUNT MODE command or an error is received. If the REVD bit in 
the GSMR_H is set, each data byte is reversed in its bit order before it is written to memory. 


You can decrease the latency of the receiver by decreasing the receive FIFO width. This 
option is enabled by the RFW bit in the GSMR_H and causes receiver overruns at higher 
transmission speeds. The receiver always checks the CRC of the received frame, according 
to the TCRC field in the GSMR_H. If a CRC is not required, the resuming errors can be 
ignored. 


16.9.21.4 ACHIEVING SYNCHRONIZATION IN TRANSPARENT MODE. Once the 
SCC2 transmitter is enabled for transparent operation in the GSMR_H, the TX buffer 
descriptor is prepared and the transmit FIFO is preloaded by the SDMA channel, another 
process must occur before data can be transmitted. It is called transmit synchronization. 
Similarly, once the SCC2 receiver is enabled for transparent operation in the GSMR_H and 
the RX buffer descriptor is made empty for the serial communication controller, another 
process must occur before data can be received and it is called receive synchronization. 
You can have bit-level control of the synchronization process when receiving and 
transmitting by using either an inline synchronization pattern or external synchronization 
signals. 
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16.9.21.4.1 Inline Synchronization Pattern. The transparent channel can be 
programmed to transmit and receive a synchronization pattern if the SYNL field in the 
GSMR_H are not zero. This pattern is defined in the data synchronization register and the 
length of the Sync pattern is defined in the SYNL field. If the SYNL field is 00, then the DSR 
is not used and an external Sync signal is used instead. See Section 16.9.4 Data 
Synchronization Register and Section 16.9.2 The General SCC2 Mode Registers for 
more information. 


DSR-SCC2 TRANSPARENT (SYNL = 01) 


4-BIT SYNC 


(IMMR & OxFFFFOO000) + OxA2E 





NOTE: X= “Don’t Care”. 


DSR-SCC2 TRANSPARENT (SYNL = 10) 


8-BIT SYNC 


(IMMR & OxFFFFO000) + OxA2E 





NOTE: X= “Don’t Care”. 


DSR-SCC2 TRANSPARENT (SYNL = 11) 


(IMMR & OxFFFFO000) + 0xA2E 
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The receiver synchronizes on the synchronization pattern that is located in the DSR. For 
instance, if 4-BIT SYNC is selected, reception begins as soon as these four bits are 
received, beginning with the first bit following the 4-BIT SYNC field. The transmitter » 
synchronizes on the receiver pattern if the RSYN bit of the GSMR_H is set. This effectively 
links the transmitter synchronization to the receiver synchronization. 


16.9.21.4.2 External Synchronization Signals. If the SYNL field of the GSMR_H is 
programmed to 00, an external signal is used to begin the sequence. The CTS pin is used 
for the transmitter and the CD pin is used for the receiver and these pins share two options— 
pulse and sampling. 


The pulse option determines whether the CD or CTS pins only need to be asserted once to 
begin reception/transmission or whether they must be asserted and stay that way for the 
duration of the transparent frame. In the GSMR_H, the CDP and CTSP bits control the pulse 
options. If you expect a continuous stream of data without interruption, then you should use 
the pulse operation. However, if you are trying to identify frames of transparent data, then 
you should use the envelope mode of these pins. 


The sampling option determines the delay between CD and CTS being asserted and the 
resulting action by the serial communication controller. You can assume that these pins are 
asynchronous to the data and internally synchronized by the serial communication controller 
or you can assume that they are synchronous to the data for faster operation. The CDS and 
CTCC bits of the GSMR_H control the sampling option. It is also an option to link the 
transmitter synchronization to the receiver synchronization. Diagrams for the 
pulse/envelope and sampling options are illustrated in Section 16.9.10 Controlling SCC2 
Timing. | 
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16.9.21.4.3 Transparent Synchronization Example. Figure 16-102 illustrates an 
example of synchronization using the external signals. 


MPC823 A MPC823 B 





NOTES: 
1. Each MPC823 generates its own transmit clocks. If the transmit and receive clocks are the same, one 
MPC823 can generate transmit and receive clocks for the other MPC823. For example, CLKx on MPC823 B could be used to 
clock the transmitter and receiver. 


BRGOx 
(OUTPUT 
IS CLKx 
INPUT) 
TXD2 
(OUTPUT 
IS RXD2 
INPUT) 


RTS : | 
(OUTPUT FIRST BIT OF FRAME DATA LAST BIT OF FRAME DATA OR CRC 
IS CD 
INPUT) 


L=1IN TX BD CAUSES NEGATION OF RTS / 





CD LOST CONDITION TERMINATES RECEPTION OF FRAME 
NOTES: | | 
1. CTS should be configured as always asserted in the port C parallel I/O or connected to ground externally. 
2. The required GSMR_x configurations are DIAG = 00, CTSS = 1, CTSP is a “don't care", CDS = 1, CDP = 0, TTX = 1, and 
TRX = 1. REVD and TCRC are application-dependent. 
3. The transparent frame contains a CRC if the TC bit is set in the TX buffer descriptor. 


Figure 16-102. Sending Transparent Frames Between MPC823s 


MPC823 A and B in Figure 16-102 exchange transparent frames and synchronize each 
other using the RTS and CD pins. However, the CTS pin is not required since transmission 
begins at any time. Thus, the RTS pin is directly connected to the other CD pin. The RSYN 
bit in the GSMR_H is not set and transmission and reception from each MPC823 is 
independent. 
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16.9.21.5 SCC2 TRANSPARENT PARAMETER RAM MEMORY MAP. In totally 
Transparent mode, the serial communication controller overlays the structure used in 
Table 16-24 with the transparent parameters described in Table 16-29. 

Table 16-29. SCC2 Transparent Parameter RAM Memory Map 


ADDRESS DESCRIPTION 


SCC2 Base + 30 CRC_P CRC Preset for Totally Transparent Mode 
SCC2 Base + 34 CRC_C CRC Constant for Totally Transparent Receiver 


NOTE: You are only responsible for initializing the items in bold. 
SCC2 Base = (IMMR & OxFFFFOOOO) + Ox3D00. 





e CRC_P—For the 16-bit CRC-CCITT, CRC_P should be initialized with OxOOOOFFFF. 
For the 32-bit CRC-CCITT, CRC_P should be initialized with OxFFFFFFFF and for the 
CRC-16, CRC_P should be initialized with ones (OxOOOOFFFF) or zeros (Ox00000000). 


¢ CRC_C—For the 16-bit CRC-CCITT, CRC_C should be initialized with OxOOOOFOB8. 
For the 32-bit CRC-CCITT, CRC_C should be initialized with OXDEBB20E38 and for the 
CRC-16 which is normally used with BISYNC, CRC_C should be initialized with 
Ox00000000. | 


Note: CRC-C overlaps with the CRC constant for the HDLC-based protocols. However, 
this overlap is not detrimental since the CRC constant is only used for the 
receiver, so only one entry is required. You can choose an HDLC transmitter with 
a transparent receiver or a transparent transmitter with an HDLC receiver. 





16.9.21.6 SCC2 TRANSPARENT COMMANDS. You can program the CPM command 
register (CPCR) with the following commands to transmit data. See Section 16.2.7.1 CPM | 
Command Register for additional information. - : 


e STOP TRANSMIT—After the hardware or software is reset and the channel is enabled 
in the SCC2 mode register, the channel is in transmit enable mode and starts polling 
the first buffer descriptor in the table every 64 clocks or immediately if the TOD bit of 
the TODR is set. This command disables the transmission of frames on the transmit 
channel and if the transparent controller receives it during frame transmission, buffer 
transmission is aborted after a maximum of 64 additional bits and the transmit FIFO is 
flushed. The TBPTR is not advanced, no new buffer descriptor is accessed and no new 
buffers are transmitted for this channel. The transmitter will send idles. 
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¢ GRACEFUL STOP TRANSMIT—This command is used to stop transmission 
smoothly, rather than abruptly, in much the same way that the regular STOP 
TRANSMIT command stops. It stops transmission after the current frame finishes or 
immediately if there is no frame being transmitted. A transparent frame is not complete 
until a buffer descriptor with the L bit set has its associated buffer completely 
transmitted. The GRA bit in the SCCE—Transparent register is set once transmission 
stops and then the transmit parameters and their buffer descriptors can be modified. | 
The TBPTR points to the next TX buffer descriptor in the table. Transmission begins 
once the R bit of the next buffer descriptor is set and the RESTART TRANSMIT | 
command is issued. par 


e RESTART TRANSMIT—This command reenables the transmission of characters on i 
the transmit channel. The transparent controller expects it after a STOP TRANSMIT ares 
command is issued, aftera GRACEFUL STOP TRANSMIT commandis issued, or after 
a transmitter error occurs. The transparent controller resumes transmission from the 
current TBPTR in the channel TX buffer descriptor table. | 


¢ INIT TX PARAMETERS—This command initializes all transmit parameters in the serial 
channel parameter RAM to their reset state. It should only be issued when the 
transmitter is disabled. The INIT TX AND RX PARAMS command can also be used to 
reset the transmit and receive parameters. 


Pe 
SiCIC 


You can program the CPM command register with the following commands to receive data. 
See Section 16.2.7.1 CPM Command Register for additional information. 


e ENTER HUNT MODE—After the hardware or software is reset and the channel is 
enabled in the GSMR_H, the channel is in receive enable mode and uses the first buffer 
descriptor in the table. This command is used to force the transparent receiver to stop 
receiving the current frame and enter hunt mode where the transparent controller is 
waiting for the synchronization sequence. After receiving the command, the current 
receive buffer is closed. Further data reception uses the next buffer descriptor. 


e CLOSE RX BD—This command is used to force the serial communication controller to 
close the RX buffer descriptor if it is currently being used and to use the next buffer 
descriptor for any subsequently received data. If the serial communication controller is 
not in the process of receiving data, no action is taken by this command. 

e INIT RX PARAMETERS—This command initializes all the receive parameters in this 
serial channel parameter RAM to their reset state and should only be issued when the 
receiver is disabled. The INIT TX AND RX PARAMS command can also be used to 
reset the receive and transmit parameters. 
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16.9.21.7 SCC2 TRANSPARENT CONTROLLER ERRORS. The serial communication 
controller reports message reception and transmission errors using the channel buffer 
descriptors, the error counters, and the SCCE-Transparent register. The following 
transmission errors can be detected by the SCC2 Transparent controller. 


e Transmitter Underrun—When this error occurs, the channel stops transmitting the 
buffer, closes it, sets the UN bit of the buffer descriptor, and generates the TXE interrupt 
if itis enabied. Tne channei resumes transmission after the RESTART TRANSMIT 
command is received. Underrun occurs after a transmit frame for which the L bit of the 
TX buffer descriptor was not set. In this case, only the TXE bit is set. Underrun cannot 
occur between transparent frames. 





¢ CTS Lost During Message Transmission—When this error occurs, the channel stops 
transmitting the buffer, closes it, sets the CT bit of the buffer descriptor, and generates 
the TXE interrupt if it is enabled. The channel resumes transmission after the 
RESTART TRANSMIT command is received. | 


The following reception errors can be detected by the SCC2 Transparent controller. 


¢ Overrun—The serial communication controller maintains an internal FIFO for receiving 
data. The communication processor module starts programming the SDMA channel if 
the data buffer is in external memory and updating the CRC when 8 or 32 bits are 
received in the FIFO. If a FIFO overrun occurs, the serial communication controller 
writes the received data byte to the internal FIFO over the previously received byte. The 
previous character and its status bits are lost. Afterwards, the channel closes the buffer, 
sets the OV bit of the buffer descriptor, and generates the RX interrupt if it is enabled. 
The receiver immediately enters hunt mode. 


¢ CD Lost During Message Reception—When this error occurs, the channel stops 
receiving messages, closes the buffer, sets the CD bit of the buffer descriptor, and 
generates the RX interrupt if it is enabled. This error has the highest priority, the rest of 
the message is lost, and no other errors are checked in the message. 


16.9.21.8 SCC2 TRANSPARENT MODE REGISTER. Since all transparent mode 
selections are in the GSMR_H, the PSMR is not used by the transparent controller. If 
transparent mode is only selected for the transmitter/receiver, then the transmitter/receiver 
can be programmed to support another piece In such a case, es can use the PSMR for 
the one protocol. | 
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16.9.21.9 SCC2 TRANSPARENT RECEIVE BUFFER DESCRIPTOR. The 
communication processor module reports information about the received data for each 
buffer using a channel’s receive (RX) buffer descriptor, closes the current buffer, generates 
a maskable interrupt, and starts receiving data into the next buffer after one of the following 
events occurs: 


e An error is detected. 

e A full receive buffer is detected. 

The ENTER HUNT MODE command is issued. , 
The CLOSE RX BD command is issued. -e 


Dey 4 Note: The communication processor module sets all the status bits in this buffer 

7 descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 







re [ees wl [| [ew] nes| oe [reserven] wo [aes on | ov | oO 
| 


| RX DATA BUFFER POINTER 


NOTE: You are only responsible for initializing the items in bold. 





E—Empty 

O= The data buffer associated with this RX buffer descriptor has been filled with data 
or has stopped receiving data because an error occurred. The core is free to 
examine or write to any fields of this RX buffer descriptor. The communication 
processor module does not use this buffer descriptor when the E bit is zero. 

1 = The data buffer associated with this buffer descriptor is empty or currently receiving 
data. This RX buffer descriptor and its associated receive buffer are owned by the 
communication processor module. Once the E bit is set, the core should not write 
any fields of this RX buffer descriptor. 


Bits 1, 7, 9-10, and 12—Reserved 
These bits are reserved and should be set to 0. 
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W—Wrap (Final Buffer Descriptor in Table) 7 
0 = This is not the last buffer descriptor in the RX buffer descriptor table. 
ine = This 1 is the last buffer descriptor in the RX buffer descriptor table. After this buffer 
_ js used, the communication processor module receives incoming data into the first 
_.  buffer‘descriptor that RBASE points to in the table. The number of RX buffer 
‘descriptors in this table is programmable and determined only by the W bit and 
overall space constraints of the dual- port RAM. 7 


|—Interrupt 


0= No interrupt is generated after this buffer is used. 
1 = When this buffer is closed by the transparent controller, the RX bit in the 
‘transparent event register is set. The RX bit can cause an interrupt if it is enabled. 


L—tLast in Frame 


— This bit is set by the transparent controller when this buffer is the last in a frame. If CD in 


envelope mode is:negated or an error has been received, one or more of the OV, CD, and 


DE bits are set. The transparent controller writes the number of frame octets to the DATA 


LENGTH field. 


‘= = This buffer i is not the last one in a frame. 
1= = - This buffer is the last one in a frame. 


- F—First | in Frame. 


The transparent controller sets this bit when this buffer is the first in the frame: 


O= The butfer is not the first in a frame. 
1 = The buffer is the first | ina frame. 


CM—Continuous Mode 


0 = Normal operation. ' 
1= The E bit is not cleared by the communication processor module after this buffer 
_ descriptor is closed, thus allowing the associated data buffer to be automatically 
overwritten next time the communication processor module accesses this buffer 
descriptor. However, the E bit is cleared if an error occurs enna reception, 
regardless of how the CM bit is set. 7 


DE—DPLL Error 


This bit is set by the transparent controller when a DPLL error occurs hile this buffer is 
being received. In decoding modes, where a transition occurs on avely bit, the DPLL error 
is set when a missing transition occurs. 


NO—RX Non- Octet 


This bit indicates that a frame containing a number of bits not exactly divisible by 8 is 
received. 
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CR—CRC Error indication bits 


This bit indicates that this frame contains a CRC error. The received CRC bytes are always 
written to the receive buffer. 


OV—Overrun 
This bit indicates that a receiver overrun has occurred during buffer reception. 


CD—Carrier Detect Lost 
This bit indicates when the CD pin is negated during buffer reception. 


DATA LENGTH 


This field represents the number of octets that the communication processor module writes 
into this buffer descriptor data buffer. The communication processor module only writes it 
once as the buffer is closed. The actual amount of memory allocated for this buffer should 
be greater than or equal to MRBLR. 


RX DATA BUFFER POINTER 


This field always point to the first location of the associated data buffer and must be divisible 
by four, unless the RFW bit in the GSMF_H is set to 8 bits wide, even or odd. The buffer can 
reside in internal or external memory. 


16.9.21.10 SCC2 TRANSPARENT TRANSMIT BUFFER DESCRIPTOR. Data is sent to 
the communication processor module for transmission on an SCC2 channel by arranging it 
in buffers referenced by the channel’s transmit (TX) buffer descriptor table. Using the buffer 
descriptors, the communication processor module confirms transmission or indicates error 
conditions so that the processor knows the buffers have been serviced. You must prepare 
the status and control bits before transmission, but they are set by the communication 
processor module after the buffer has been transmitted. 


pt fb | re | om RESERVED eter 


| DATA LENGTH 


3 TX DATA BUFFER POINTER 


NOTE: You are only responsible for initializing the items in bold. 





Note: The communication processor module sets all the status bits in this buffer 
descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 
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R—Ready aa 

0= The data buffer associated with this buffer descriptor is not ready for transmission. 
You are free to manipulate this buffer descriptor or its associated data buffer. The 
communication processor module clears this bit after the buffer is transmitted or 
after an error condition is encountered. 

1 = The data buffer, which you have prepared for transmission, is not transmitted yet 
or is currently being transmitted. You cannot write any fields of this buffer descriptor 
once this bit is set. 


Bits 1 and 7—13—Reserved 
These bits are reserved and should be set to 0. 


W-—Wrap (Final Buffer Descriptor in Table) 


O= This is not the last buffer descriptor in the TX buffer descriptor table. 

1 = This is the last buffer descriptor in the TX buffer descriptor table. After this buffer is 
used, the communication processor module receives incoming data into the first 
buffer descriptor that TBASE points to in the table. The number of TX buffer 
descriptors in this table is programmable and determined only by the W bit and 
overall space constraints of the dual-port RAM. 


I—Interrupt 


0 = No interrupt is generated after this buffer is serviced. 
_1= When this buffer is serviced by the communication processor module, the TX or 
TXE bit is set in the Sera anspatent register. These bits can cause interrupts 
if they are enabled. 


L—Last in Message 


0 = The last byte in the buffer is not the last byte in the transmitted transparent frame. 
Data from the next transmit buffer is transmitted immediately after the last byte of 
this buffer. | 

1 = The last byte in the buffer is the last byte in the transmitted transparent frame. After 
this buffer is transmitted, the transmitter requires synchronization before the next 
buffer is transmitted. 


TC—Transmit CRC 


0 = No CRC sequence is transmitted after this buffer. 
1 = A frame check sequence that is defined by the TCRC field in the GSMF_H is 
transmitted after the last byte of this buffer. 


CM—Continuous Mode 


O = Normal operation. 

1= The R bit is not cleared by the communication processor module after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
retransmitted next time the communication processor module accesses this buffer 
descriptor. However, the R bit is cleared if an error occurs during transmission, 
regardless of how the CM bit is set. 
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UN—Underrun 


This bit indicates that the serial communication controller has encountered a transmitter 
underrun condition while transmitting the associated data buffer. 


CT—CTS Lost 
This bit indicates the CTS signal has been lost during frame transmission. 


DATA LENGTH 


This field represents the number of bytes that the communication processor module should 
transmit from this buffer descriptor data buffer. It should be greater than zero and can be 
even or odd. This value is never modified by the communication processor module. 


TX DATA BUFFER POINTER 


This field always points to the first byte of the associated data buffer. It can be even or odd, 
and can reside in internal or external memory. 


16.9.21.11 SCC2 TRANSPARENT EVENT REGISTER. When the SCC2 is in transparent 
mode, the 16-bit, memory-mapped SCC2 event register is referred to as the SCC2 
transparent event register (SCCE-—Transparent). Since each protocol has specific 
requirements, the SCCE bits are different for each implementation. This register is used to 
report events recognized by the transparent channel and to generate interrupts. When an 
event is recognized, the transparent controller sets the corresponding bit in this register. 
Interrupts generated by this register can be masked in the SCCM-Transparent register. 


A bit is reset by writing a 1 (writing a zero has no effect) and more than one bit can be reset 
at a time. All unmasked bits must be reset before the communication processor module 
negates the internal interrupt request signal. This register is cleared at reset and can be read 
at any time. 


SCCE-TRANSPARENT 


me EES 
ee 


(IMMR & OxFFFFO000) + 0xA30 





Bits 0-2, 6-7, and 9-10—Reserved 
These bits are reserved and should be set to 0. 


GLR—Glitch on RX 


This bit indicates that the the serial communication controller has found a glitch on the 
receive clock. 
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GLT—Glitch on TX 


This bit indicates that the the serial communication controller has found a glitch on the 
transmit clock. 


DCC—DPLL CS Changed 

This bit indicates when the carrier sense status that is generated by the DPLL changes 
state. The real-time status can be found in the SCCS—Transparent register. This is not the 
CD pin status that is mentioned elsewhere and it is only valid when the DPLL is used. 


GRA—Gracetul Stop Complete 

This bit indicates when a graceful stop initiated by the GRACEFUL STOP TRANSMIT 
command has completed. This bit is set as soon as the transmitter finishes any frame that 
was in progress when the command was issued. It is set immediately if no frame was in 
progress when the command was issued. , 


TXE—TX Error 


This bit indicates that an error has occurred on the transmitter channel. The | bit in the 
transmit buffer descriptor must be set in order to get an update of this bit. 


RCH—Receive Character 


This bit indicates that a byte or word has been received and written to the buffer, depending 
on how the RFW bit is set in the GSMR_H. 


BSY—Busy Condition 


This bit indicates that a byte or word has been received and discarded due to a lack of 
buffers. The receiver resumes reception after it gets an ENTER HUNT MODE command. 


TX—TX Buffer 


This bit indicates that a buffer has been transmitted. This bit is set no sooner than when the 
last bit of the last byte of the buffer begins its transmission, assuming the L bit of the TX 
buffer descriptor is set. If it is not set, TX is set when the last byte of data is written to the 
transmit FIFO. The | bit in the transmit buffer descriptor must be set in order to get an update 
of this bit. | 


RX—RX Buffer 


This bit indicates that a complete buffer has been received on the SCC2 channel. This bit is 
set no sooner than two serial clocks after the last bit of the last byte in which the buffer is 
received on the RXD2 pin. The | bit in the receive buffer descriptor must be set in order to 
get an update of this bit. 
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16.9.21.12 SCC2 TRANSPARENT MASK REGISTER. When the SCC2 is in transparent 
mode, the 16-bit read/write SCC2 mask register is referred to as the SCC2 transparent mask 
(SCCM-—Transparent) register. Since each protocol has specific requirements, the SCCM 
bits are different for each implementation. It has the same bit format as the 
SCCE-Transparent register. If a bit in this register is 1, the corresponding interrupt in the 
this register is enabled. If the bit is zero, the corresponding interrupt in the this register is 
masked. 


SCCM-TRANSPARENT 


Fresenveo [aun | or 


a ce 


IMMR & OxFFFFOO00) + 0xA34 





16.9.21.13 SCC2 TRANSPARENT STATUS REGISTER. When the SCC2 is in 
transparent mode, the 8-bit read-only SCC2 status register is referred to as the SCC2 
transparent status (SCCS—Transparent) register. Since each protocol has specific 
requirements, the SCCM bits are different for each implementation. This register allows you 
to monitor real-time status conditions on the RXD2 line. The real-time status of the CTS and 
CD pins are part of the port C parallel |/O. Since each protocol has specific requirements, 
the SCCS bits are different for each implementation. 


| RESERVED RESERVED 
(IMMR & OxFFFFO00O) + 0xA37 


Bits O—5 and 7—Reserved 
These bits are reserved and should be set to O. 


SCCS-TRANSPARENT 
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CS—Carrier Sense (DPLL) | 
This bit shows the real-time internal CS signal, as determined by the DPLL. 


0 = The DPLL does not sense a carrier. 
1 = The DPLL senses a carrier. 
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16.9. 21. 14 SCC2 TRANSPARENT PROGRAMMING EXAMPLE. The following is an 
example initialization sequence for SCC2 in transparent mode. The transmitter and receiver 
_are both enabled, but operate independently of each other. They implement the connection 
illustrated on MPC823(B) in Figure 16-102. The transmit and receive clocks are externally 
provided to MPC823(B) using the CLK3 pin. SCC2 is used. The transparent controller is 
configured with the RTS2 and CD2 pins active and CTS2 is grounded internally by the 
COnNQUISLION in port C. A 16-bit CRC-CCITT is sent with each transparent frame. The FIFOs 


ao am omond anmm al £ 


aré configured for fast operation.. 








1. Configure the port A pins to enable the TXD2 and RXD2 pins. Write PAPAR bits 13 
and 12 with ones and then PADIR and PAODR bits 13 and 12 with zeros. 


2. Configure the port C pins to enable RTS2, CTS2, and CD2. Write PCPAR bit 14 with 
one and bits 8 and 9 with zero, PCDIR bits 14, 9, and 8 with zero, and PCSO bits 8 
and 9 with one. 


3. Configure port A to enable the CLK3 pin. Write PAPAR bit 5 with a one and PADIR 
_ bit 5 with a zero. 


4. Connect the CLKS3 pin to SCC2 using the serial interface. Write the R2CS and T2CS 
bits of the SICR to 110.. 


5. Connect the SCC2 to the NMSI and clear the sce bit of the SICR. 
6. Write the SDCR with the appropriate arbitration ID. 


7. Write RBASE and TBASE in.the SCC2 parameter RAM to point to the RX buffer 

_ descriptor and TX buffer descriptor in the dual-port RAM. Assuming one RX buffer 
descriptor.at the beginning of dual-port RAM and one TX buffer descriptor following 
that RX buffer descriptor, write RBASE with 0x2000 and TBASE with 0x2008. 


8. Program the CPCR to execute the INIT RX AND TX PARAMS command for the serial 
communication controller. To execute this command for SCC2, write ove: to the 
CPCR. | , 


9. Write RFCR and TFCR with 0x18 for normal aperaiion: 


10.Write MRBLR with the maximum number of oe per receive buffer and assume 16 
bytes, so MRBLR = 0x0010. 


11. Write CRC_P with Ox0000FFFF to comply with the 16-bit CRC-CCITT. 
12. Write CRC_C with OxOO000FOB8 to comply with the 16-bit CRC-CCITT. 


13. Initialize the RX buffer descriptor. Assume the RX data buffer is at 0x00001000 in main 
~ memory. Write OxBOO00 to RX_BD_Status, 0x0000 to RX_BD_Length (optional), and 
0x00001000 to RX_BD_Pointer. 

14. Initialize the TX buffer descriptor. Assume the TX data buffer is at Ox00002000 in main 
memory and contains five 8-bit characters. Write OxBC0O to TX_BD_Status, 0x0005 
to TX_BD Length, and 0x00002000 to TX_BD_Pointer. 

15. Write OxFFFF to the SCCE-Transparent to clear any previous events. 

16. Write 0x0013 to the SCCM-Transparent to enable the TXE, TX, and RX interrupts. 


17. Write 0x20000000 to the CIMR s so the SCC2 can generate a sysien! interrupt. The 
CICR should also be initialized. 
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18.Write 0x00001980 to the GSMR_H to configure the transparent channel. 


19. Write 0x00000000 to the GSMR_L to configure the CTS and CD pins to automatically 
control transmission and reception (DIAG field). Normal operation of the transmit clock 
is used. Notice that the transmitter (ENT) and receiver (ENR) are not enabled yet. 


20.Write Ox00000030 to the GSMR_L to enable the SCC2 transmitter and receiver. This 
additional write ensures that the ENT and ENR bits are enabled last. 


Note: After 5 bytes are transmitted, the TX buffer descriptor is automatically closed. 
The receive buffer is automatically closed after 16 bytes are received. Any data 
received after 16 bytes causes a busy (out-of-buffers) condition since only one 
RX buffer descriptor is prepared. 


16.9.22 The SCC2 in Ethernet Mode 


The Ethernet IEEE 802.3 protocol is a widely used LAN-based on the carrier-sense multiple 
access/collision detect (CSMA/CD) approach. Ethernet and IEEE 802.3 protocols are very 
similar and can coexist on the same LAN. They are referred to synonymously as Ethernet 
in this manual, unless specifically noted. Ethernet and IEEE 802.3 frames are based on the 
frame structure illustrated in Figure 16-103. 


FRAME LENGTH IS 64-1518 BYTES 


ae aessee Renee a RS 
START FRAME 
DEST SOURCE | TYPE/ 
PREAMBLE FRAME DATA CHECK 


7 BYTES 1BYTE 6BYTES 6BYTES 2BYTES 46-1500 BYTES 4 BYTES 


NOTE: The LSB of each octet is transmitted first. 
Figure 16-103. Ethernet Frame Format 


The frame begins with a 7-byte preamble of alternating ones and zeros. Since the frame is 
Manchester encoded, the preamble gives receiving stations a known pattern on which to 
lock. The start frame delimiter signifies the beginning of the frame and follows the preamble. 
The 48-bit destination address is next, followed by the 48-bit source address. Original 
versions of the IEEE 802.3 specification allowed 16-bit addressing. However, this 
addressing has never been widely used in the industry. 


The next field is the type field in Ethernet and the length field in IEEE 802.3. The type field 
signifies the protocol used in the rest of the frame and the length field specifies the length of 
the data portion of the frame. For Ethernet and IEEE 802.3 frames to coexist on the same 
LAN, the length field of the frame must always be unique from any type fields used in 
Ethernet. This has limited the length of the data portion of the frame to 1,500 bytes and the 
total frame length to 1,518 bytes. The last 4 bytes of the frame are the frame check 
sequence (FCS), which is the standard 32-bit CCITT-CRC polynomial used in many other 
protocols. 
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When a station needs to transmit, it checks for activity on the LAN and when the LAN 
becomes silent for a specified period, the station starts transmitting. At that time, the station 
continually checks for collision on the LAN and if one is found, the station forces a jam of all 
ones on its frame and stops transmitting. Collisions usually occur close to the beginning of 
a frame. The station waits a random period of time, called a backoff, before trying to transmit 
again. Once the backoff is complete, the station waits for silence on the LAN and then 
begins retransmission on the LAN, which is called a retry. If the frame is not successfully 
transmitted within 15 retries, an error occurs. Tne i0iMbps Etnernet provides 0.8us per byie. 
The preamble plus start frame delimiter is transmitted in 6.4us. The minimum interframe gap 
is 9.6us and the slot time is 52us. Therefore, you must operate the MPC823 at a minimum 
frequency of 2OMHz to implement Ethernet. 


16.9.22.1 FEATURES. The following list summarizes the main features of the SCC2 in 
Ethernet mode: 

e Performs MAC layer functions of Ethernet and IEEE 802.3 

e Full-duplex operation support 

e Performs framing functions 

e Full collision support 

e Maximum 10Mbps (10BASE-T) bit rate 

e Back-to-back frame reception 

e Detection of receive frames that are too long 

e Multibuffer data structure 

¢ Supports 48-bit addresses in three modes 

e Up to eight parallel I/O pins can be sampled and appended to any frame 

¢ Heartbeat indication 

e Transmitter network management and diagnostics 

e Receiver network management and diagnostics 

e Error counters 

e Internal and external loopback mode 
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16.9.22.2 ETHERNET ON THE MPC823. When the MODE field in the general SCC2 
mode low register (GSMR_L) selects the SCC2 to be in Ethernet mode, the serial 
communication controller performs the full set of IEEE 802.3/Ethernet CSMA/CD media 
access control and channel interface functions. The SCC2 in Ethernet mode is also referred 
to as the SCC2 Ethernet controller in this manual. 


U-BUS 





SLOT TIME 
AND DEFER 
COUNTER 


RANDOM NO. 


CONTROL 
REGISTERS 







RX CLOCK 
TX CLOCK 


: CLOCK 


PERIPHERAL BUS GENERATOR 


INTERNAL CLOCKS 






TRANSMITTER RTS = TENA 
CONTROL 


RECEIVE TRANSMIT 
DATA DATA 
FIFO FIFO 


conn —e} aro 
CTS =CLSN UNIT eens 


CTS = CLSN 


UNIT 





RXD2 SHIFTER SHIFTER TXD2 


Figure 16-104. Ethernet Block Diagram 


The SCC2 in Ethernet mode requires an external serial interface adaptor (SIA) and — 
transceiver function to complete the interface to the media. This function is implemented in 
the Motorola MC68160 enhanced Ethernet serial transceiver (EEST). 


The MPC823+EEST solution provides a direct connection to the attachment unit interface 
(AUI) or twisted-pair (10OBASE-T). The EEST provides a glueless interface to the MPC823, 
Manchester encoding and decoding, automatic selection of 1OBASE-T versus AUI ports, 
10BASE-T polarity detection and correction, LED drivers, and a low-power mode. For more 
information, refer to the MC68160 device description. 


The SCC2 Ethernet controller also provides a number of features. Although the MPC823 
contains DPLLs that allow Manchester encoding and decoding, these DPLLs were not 
designed for Ethernet rates. Therefore, the SCC2 Ethernet controller bypasses the on-chip 
DPLLs and uses the external system interface adaptor on the EEST instead. 
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16.9.22.3 UNDERSTANDING ETHERNET ON THE MPC823. You are encouraged to 
learn about the basic functionality of the SCC2 and the overall architecture of the 
communication processor module before delving into the functionality of the SCC2 in 
Ethernet mode. It is important that first-time users of the MPC823 who plan to use Ethernet 
read the following sections of this manual first. | 


e Section 16.2 The RISC Microcontroller, Section 16.2 The RISC Microcontroller, 
and Section 16.2.7.3 Duai-Port RAM explain how the RISC microconirolier issues 
special commands to the Ethernet channel. The dual-port RAM loads Ethernet 


parameters and initializes buffer descriptors for the Ethernet channel to use. 


Section 16.5 The SDMA Channels explains how SDMA channels are used to transfer 
data to or from the Ethernet channel and system memory. 





-* Section 16.7.8 Nonmultiplexed Serial Interface Configuration explains how clocks 
are routed to the SCC through the bank of clocks. 


Section 16.9.22 The SCC2 in Ethernet Mode explains how to program the SCC2 in 
Ethernet mode. 


Section 16.14 The Parallel I/O Ports explains how to configure the preferred Ethernet 
pin functions to be active. 


Section 16.15 The CPM Interrupt Controller defines the interrupt priority of the serial 
communication controller and how interrupts are generated to the core. 


Section 12.3 Interrupt Configuration contains an overview of the MPC823 interrupt 
structure and explains how to set up interrupt control. 


16.9.22.4 CONNECTING THE MPC823 TO THE EEST. The interface to the external 
EEST chip consists of the following Ethernet pins: 


e Receive clock (RCLK)—The CLK1, CLK2, CLK3, or CLK4 a that is routed through the 
bank of clocks on the MPC823. 


Transmit clock (TCLK)—The CLK1, CLK2, CLK3, or CLK4 pin that is routed through the 
bank of clocks on the MPC823. RCLK and TCLK should not be connected to the same 
CLKx pin since the EEST provides a separate receive and transmit clock signal. 


Transmit data (TXD2)—The MPC823 TXD2 pin. 
e Receive data (RXD2)—The MPC823 RXD2 pin. 
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Figure 16-105 illustrates the basic components and pins required to make the Ethernet 
connection between the MPC823 and EEST. 


MPC823 FEST 
MC68160 






RJ-45 


| | TWISTED PAIR 


D-15 


SCC2 Txp2 
TENA (RTS) 
TCLK (CLKx) 


RXD2 

RENA (CD) 
RCLK (CLKx) 
CLSN (CTS) 







a tn 







HCY 








PARALLEL I/O 





START FRAME 
DEST | SOURCE | TYPE/ 
PREAMBLE | FRAME | — DATA CHECK 


7 BYTES 1BYTE | 6BYTES 6BYTES 2BYTES 46-1500 BYTES 4 BYTES” 





STORED IN TRANSMIT BUFFER 
STORED IN RECEIVE BUFFER 








NOTE: The MPC823 automatically pads the short transmit frames. 
Figure 16-105. Connecting the MPC823 to Ethernet 


The following pins function differently when the SCC2 is in Ethernet mode than when it is in 
other protocols: | | 


e Transmit Enable (TENA)—The RTS pin changes to TENA when the SCC2 is in 
Ethernet mode. The polarity of TENA is active high, whereas the polarity of RTS is 
active low. 

¢ Receive Enable (RENA)—The CD pin changes to RENA when the SCC2 is in Ethernet 
mode. The polarity of RENA is active high, whereas the polarity of CD is active low. 


¢ Collision (CLSN)—The CTS pin changes to CLSN when the SCC2 is in Ethernet mode. 
The polarity of CLSN is active high, whereas the polarity of CTS is active low. 


Note: The carrier sense signal is referenced in Ethernet descriptions because it 
indicates when the LAN is being used. Carrier sense is defined as RENA OR’ed 
with CLSN. 
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The EEST has similar names for its connection to the seven MPC823 pins mentioned above 
and contains a loopback pin so the MPC823 can perform external loopback testing. This can 
be controlled by any available parallel I/O pin on the MPC823. The passive components that 
are needed to connect to AUI or twisted-pair media are external to the EEST. For more 
information on the EEST connection circuits, refer to the MC68160 device description. 


Using the SDMA channels, the MPC823 stores every byte that is received after the start 
frame deiimiier in system memory. When iransmitting, you provide the destination address, 
source address, type/length field, and the transmit data. The MPC823 automatically pads 
frames with less than 46 bytes in the data field to meet the minimum frame requirements. In 
addition, the MPC823 appends the FCS to the frame. 


16.9.22.5 SCC2 ETHERNET CHANNEL FRAME TRANSMISSION PROCESS. The 
Ethernet transmitter is designed to work with almost no intervention from the core. When the 
core enables the transmitter, the SCC2 in Ethernet mode polls the first TX buffer descriptor 
in the channel TX buffer descriptor table every 128 serial clocks. If you have a frame to 
transmit, you can set the TOD bit in the TODR to avoid having to wait for the next poll to 
occur. See Section 16.9.5 Transmit-on-Demand Register for more information. 


To begin transmission, the SCC2 in Ethernet mode (also called the SCC2 Ethernet 
controller) fetches the data from the data buffer, asserts TENA to the EEST, and starts 
transmitting the preamble sequence, the start frame delimiter, and frame information. — 
However, the SCC2 Ethernet controller defers transmission if the line is busy. Before 
transmitting, it waits for carrier sense to become inactive and stay that way for 6.Ous. If it 
does, then the SCC2 Ethernet controller starts transmitting after waiting an additional 3.6us 
(9.6us after carrier sense originally became inactive). 


lf a collision occurs during frame transmission, the SCC2 Ethernet controller follows the 
specified backoff procedure and tries to retransmit the frame until the retry limit threshold is 
reached. The SCC2 Ethernet controller stores the first 5 to 8 bytes of the transmit frame in 
internal RAM, so that they do not have to be retrieved from system memory in case of a 
collision. This improves bus utilization and latency when the backoff timer output requires 
an immediate retransmission. If a collision occurs during frame transmission, the SCC2 
Ethernet controller returns to the first buffer for a retransmission. The only restriction is that 
the first buffer must contain at least 9 bytes. 


a7 4 Note: If an Ethernet frame is made up of multiple buffers, you should not reuse the first 
buffer descriptor until the last buffer descriptor of the frame has had its i bit 
cleared by the communication processor module. 
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When the end of the current buffer descriptor is reached and the L bit in the TX buffer 
descriptor is set, the FCS bytes of the Ethernet frame are appended (if the TC bit is set in 
the TX buffer descriptor), and TENA is negated. This notifies the EEST of the need to 
generate the illegal Manchester encoding that signifies the end of an Ethernet frame. After 
CRC transmission, the SCC2 Ethernet controller writes the frame status bits into the buffer 
descriptor and clears the R bit. When the end of the current buffer descriptor is reached and 
the L bit is not set, only the R bit is cleared. 


In either mode, an interrupt can be issued, depending on how the | bit is set in the TX buffer 
descriptor. The SCC2 Ethernet controller then proceeds to the next TX buffer descriptor in 
the table. You can be interrupted after each frame, after each buffer, or after a specific buffer 
is transmitted. The SCC2 Ethernet controller can add pad characters to short frames. If the 
PAD bit is set in the TX buffer descriptor, the frame is padded up to the value of the minimum 
frame length register. 


To rearrange the transmit queue before the communication processor module finishes 
transmitting all the frames, issue the GRACEFUL STOP TRANSMIT command. This 
technique can be useful for transmitting expedited data before previously linked buffers or 
for error situations. When the GRACEFUL STOP TRANSMIT command Is issued, the 
Ethernet controller stops immediately if no transmission is in progress or it will keep 
transmitting until the current frame either finishes or terminates with a collision. When the 
Ethernet controller receives the RESTART TRANSMIT command, it resumes transmission. 
The Ethernet controller transmits bytes least-significant bit first. 


16.9.22.6 SCC2 ETHERNET CHANNEL FRAME RECEPTION PROCESS. The Ethernet 
receiver is designed to work with almost no intervention from the core and can perform 
address recognition, CRC checking, short frame checking, maximum DMA transfer 
checking, and maximum frame length checking. . 


When the core enables the Ethernet receiver, it enters hunt mode as soon as the RENA 
signal is asserted if CLSN is negated. In hunt mode, as data is shifted into the receive shift 
register one bit at a time, the contents of the register are compared to the contents of the 
SYN1 field in the data synchronization register. This compare function becomes valid a 
certain number of clocks after the start of the frame (depending on the NIB bits in the 
PSMR-Ethernet). If the two are not equal, the next bit is shifted in and the comparison is 
repeated. If a double zero or double one fault is detected between bits 14 to 21 from the start 
of the frame, it is rejected. If a double zero fault is detected after 21 bits from the start of the 
frame and before detection of the start frame delimiter, the frame is also rejected. When the 
registers match, hunt mode is terminated and character assembly begins. 


When the receiver detects the first bytes of the frame, the Ethernet controller performs 
address recognition functions on the frame. The receiver can receive physical (individual), 
group (multicast), and broadcast addresses. Ethernet receive frame data is not written to 
memory until the internal address recognition algorithm is complete, which improves bus 
utilization with frames not addressed to this station. 
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lf a match is found, the Ethernet controller fetches the next RX buffer descriptor and, if it is 
empty, starts transferring the incoming frame to the RX buffer descriptor associated data 
buffer. If a collision is detected during the frame, the RX buffer descriptors associated with 
this frame are reused. Thus, there will be no collision frames presented to you except late 
collisions, which indicate serious LAN problems. When the data buffer has been filled, the 
Ethernet controller clears the E bit in the RX buffer descriptor and generates an interrupt if 
the | bit is set. If the incoming frame exceeds the length of the data buffer, the Ethernet 
controller fetches the next RX buffer descriptor in the table and, if it is empty, continues 
transferring the rest of the frame to this buffer descriptor associated data buffer. The RX 
buffer descriptor length is determined in the MRBLR value in the SCC2 parameter RAM. 
You should program the MRBLR to be at least 64 bytes. | 
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During reception, the Ethernet controller checks for a frame that is either too short or too 

long. When the frame ends, the receive CRC field is checked and written to the data buffer. 
The data length written to the last buffer descriptor in the Ethernet frame is the length of the 
entire frame and it enables the software to correctly recognize the frame-too-long condition. 


The Ethernet controller then sets the L bit in the RX buffer descriptor, writes the other frame 
status bits into the RX buffer descriptor, and clears the E bit. Then it generates a maskable 
interrupt, which indicates that a frame has been received and is in memory. The Ethernet 
controller then waits for a new frame. It receives serial data least-significant bit first. 


16.9.22.7 SCC2 ETHERNET PARAMETER RAM MEMORY MAP. When configured to 
operate in Ethernet mode, the SCC2 overlays the structure used in Table 16-24 onto the 
parameters described in Table 16-30. 


Table 16-30. SCC2 Ethernet Parameter RAM Memory Map 


ADDRESS | NAME WIDTH DESCRIPTION 
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Table 16-30. SCC2 Ethernet Parameter RAM Memory Map (Continued) 
























NOTE: You are only responsible for initializing the items in bold. SCC2 Base = (IMMR & OxFFFF0000) + 0x3D00. 
* The bytes inside each half-word are reversed. a | 
All references to registers in the parameter RAM table are actually implemented in the dual-port RAM area as a memory-based 
register. 
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¢ C_PRES—For 32-bit CRC-CCITT, C_PRES should be initialized with OxFFFFFFFF. 
¢ C MASK—For 32-bit CRC-CCITT, C_MASK should be initialized with OxDEBB20E3. 


¢ CRCEC, ALEC, and DISFC—These 32-bit (modulo 2°*) counters are maintained by the 
communication processor module and you can initialize them while the channel is 
disabled. CRCEC is incremented for each received frame with a CRC error, except it 
does not include frames not addressed to you, frames received in the out-of-buffers 
condition, frames with overrun errors, or frames with alignment errors. ALEC is 
incremented for frames received with dribbling bits, but does not include frames not 
addressed to you, frames received in. the out-of-buffers condition, or frames with 
overrun errors. DISFC is incremented for frames discarded because of the 
out-of-buffers condition or an overrun error. The CRC does not have to be correct for 


this counter to be incremented. 





e PADS—You must write the pattern of the pad characters that should be sent when short 
frame padding is implemented into this 16-bit register. The byte pattern written to the 
register may be of any value, but both the high and low bytes should be the same. 


e¢ RET_LIM—You must write the number of retries that should be made to transmit a 
frame into this 16-bit register. This value is typically OxF. If the frame is not transmitted 
after this limit is reached, an interrupt can be generated. | 


¢ RET_CNT is a temporary down-counter used to count the number of retries made. 


e MFLR—The SCC2 Ethernet controller checks the length of an incoming Ethernet frame 
against the user-defined value given in this 16-bit register. Typically this register is set 
to Ox5EE. If this limit is exceeded, the remainder of the incoming frame is discarded and 
the LG bit is set in the last RX buffer descriptor belonging to that frame. The SCC2 
Ethernet controller reports the frame status and length in the last RX buffer descriptor. 
MELR is defined as all the in-frame bytes between the start frame delimiter and the end 
of the frame. 


e MINFLR—The SCC2 Ethernet controller checks the length of an incoming Ethernet 
frame against the user-defined value given in this 16-bit register that is typically set to 
0x40. If the received frame length is less than the register value, then this frame is 
discarded unless the RSH bit in the PSMR-SCC2 Ethernet is set. If RSH is-set, then 
the SH bit is set in the last RX buffer descriptor belonging to that frame. For transmit 
operation when the frame is too short, the SCC2 Ethernet controller adds PADs to the 
transmitted frame, depending on how the PAD bit is set in the TX buffer descriptor and 
the PAD value in the parameter RAM. Pad characters are added to make the transmit 
frame MINFLR bytes in length. 


e MAXD1—This parameter gives you the option to stop system bus writes from occurring 
after a frame has exceeded a certain size. However, the value of this register is valid 
only if an address match is found. The SCC2 Ethernet controller checks the length of 
an incoming Ethernet frame against the user-defined value given in this 16-bit register 
that is usually set to Ox5FO. If this limit is exceeded, the remainder of the incoming frame 
is discarded. The SCC2 Ethernet controller waits to the end of the frame or until MFLR 
bytes have been received and reports the frame status and the frame length in the last 
RX buffer descriptor. : | 
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e MAXD2—This parameter also gives you the option to stop system bus writes from 
occurring after a frame has exceeded a certain size. However, the value of this register 
is valid in promiscuous mode when no address match is detected. The SCC2 Ethernet 
controller checks the length of an incoming Ethernet frame against the user-defined 
value given in this 16-bit register that is usually set to Ox5FO. If this limit is exceeded, 
the remainder of the incoming frame is discarded. The SCC2 Ethernet controller waits 
until the end of the frame or until MFLR bytes have been received and reports the frame 
status and length in the last RX buffer descriptor. In a monitor station, MAXD2 can be 
programmed to a value much less than MAXD1 to receive entire frames addressed to 
this station, but receives only the headers of the other frames. 


rg 
¢ MAXD—For internal use only. 2 


¢ MAX_B—For internal use only. 3 | 
e DMA_CNT is a temporary down-counter used to track the frame length. 


e GADDR1-—4—These four registers are used in the hash table function of the group 
addressing mode. You can write zeros to these values after reset and before the 
Ethernet channel is enabled to disable all group hash address recognition functions. 
The SET GROUP ADDRESS command is used to enable the hash table. 


e TBUFO_DATAO—For internal use only. 
e TBUFO_DATA1—For internal use only. 
e TBUFO_RBAO—For internal use only. 
° TBUFO_CRC—For internal use only. 

e TBUFO_BCNT—For internal use only. 


¢ PADDR1—You must write the 48-bit individual address of this station into this location. 
PADDR 1_L is the lowest order half-word and PADDR1_H is the highest order 
half-word. PADDR_M is the middle half-word. | 


e P_PER—This parameter allows the SCC2 Ethernet controller to be less aggressive 
after a collision. Normally, this parameter should be set to Ox0000. To decrease the 
aggressiveness of the SCC2 Ethernet controller, you can set P_PER to a value 
between 1 and 9, with 9 being the least aggressive. The P_PER value is added to the 
retry count in the backoff algorithm to reduce the probability of transmission on the next 
time slot. 


Note: Using P_PER is fully allowed in the Ethernet/802.3 specifications. In a heavily 
congested Ethernet LAN, a less aggressive backoff algorithm used by multiple 
stations on the LAN increases the overall LAN throughput by reducing the 
probability of collisions. The SBT bit in the PSMR-SCC2 Ethernet offers another _ 
way to reduce the aggressiveness of the SCC2 Ethernet controller. 
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e RFBD_PTR—For internal use only. This coer ene the first RX buffer descriptor 
pointer. 


-¢ TFBD_PTR—For internal use only. This register contains the first TX buffer descriptor 
pointer. 


e TLBD_ PTR—For internal use only. This register contains the last TX buffer descriptor 
pointer. 


e TX_LEN—For internal use only. 


e |[ADDR1—4 —These four registers are used in the hash table function of the individual 
addressing mode. You can write zeros to these values after reset and before the 
Ethernet channel is enabled to disable all individual hash address recognition functions. 
The SET GROUP ADDRESS command is used to enable the hash table. 


¢ BOFF_CNT—For internal use only. 


e TADDR—This parameter allows you to add and delete addresses from the individual 
and group hash tables. After placing an address in TADDR, you must issue the SET 
GROUP ADDRESS command. TADDR_L is the lowest order half-word and TADDR_H 
is the highest order half-word. TADDR_M is the middle half-word. 


16.9.22.8 CONFIGURING THE SCC2 ETHERNET PARAMETERS. You configure the 
SCC2 to operate as an SCC2 Ethernet controller by setting the MODE field in the general 
SCC2 mode low register (GSMR_L). The receive errors are reported in the RX buffer 
descriptor and the transmit errors are reported in the TX buffer descriptor. Several fields in 
the GSMR_H and GSMR_L must be programmed to special values for Ethernet. You should 
program the data synchronization register (DSR) using the table below. The GSMR_L 
programs the first six bytes of the preamble and the SYN1 field of the DSR programs the 
seventh byte (0x55) of the preamble. Program the 1-byte start delimiter with the value OxD5 
in the SYN2 field of the DSR. Refer to Section 16.9.2 The General SCC2 Mode Registers 
for more information. 


DSR 


ae ee S See ee es 


(IMMR & OxFFFF0000) + 0xA2E 





SYN2—Synchronization 2 


This field represents the start frame delimiter for an Ethernet frame. You must set this field 
to OxD5. 


SYN1—Synchronization 1 


This field represents the seventh byte of the preamble for the Ethernet frame. You must set 
this field to 0x55. 
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16.9.22.9 SCC2 ETHERNET COMMANDS. You can program the CPM command register 
(CPCR) with the following commands to transmit data. See Section 16.2.7.1 CPM 
Command Register for additional information. 


| “Oo Note: Before issuing a CPM reset (RST bit in the CPCR), configure the TENA pin as 
| an input. 


e STOP TRANSMIT—When used with the SCC2 Ethernet controller, this command 
violates a specific behavior of an Ethernet/IEEE 802.3 station. It should not be used. / 


e GRACEFUL STOP TRANSMIT—This command is used to ensure that transmission a 
stops smoothly after the current frame finishes or undergoes a collision. The GRA bit in | 
the SCCE-Ethernet register is set once transmission stops. Then you can modify the 
Ethernet transmit parameters and their buffer descriptors. The TBP TR points to the 
next TX buffer descriptor in the table. Transmission begins once the R bit of the next 
buffer descriptor is set and the RESTART TRANSMIT command is issued. 


aren ean tint tr A 


“OO Note: If the GRACEFUL STOP TRANSMIT command is issued and the current 
transmit frame ends in a collision, the TBPTR points to the beginning of the 
collided frame with the R bit still set in the TX buffer descriptor. The frame will 
look as if it was never transmitted. 


e RESTART TRANSMIT—This command enables the transmission of characters on the 
transmit channel. The SCC2 Ethernet controller expects it after a GRACEFUL STOP 
TRANSMIT command is issued or a transmitter error occurs. The SCC2 Ethernet 
controller resumes transmission from the current TBPTR in the channel TX buffer 
descriptor table. 


e INIT TX PARAMETERS—This command initializes all the transmit parameters in this 
serial channel parameter RAM to their reset state. It should only be issued when the 
transmitter is disabled. The INIT TX AND RX PARAMS command can also be used to 
reset the transmit and receive parameters. 


You can program the CPM command register with the following commands to receive data. 
See Section 16.2.7.1 CPM Command Register for additional information. | 


e ENTER HUNT MODE—After the hardware or software is reset and the channel in the 
SCCM-Ethernet register is enabled, the channel is in receive enable mode and uses 
the first buffer descriptor in the table. This command is generally used to force the 
Ethernet receiver to stop receiving the current frame and enter hunt mode. In this mode, 
the SCC2 Ethernet controller continually scans the input datastream for a transition of 
carrier sense from inactive to active and then a preamble sequence followed by the start 
frame delimiter. After receiving the command, the current receive buffer is closed and 
the CRC calculation is reset. The next RX buffer descriptor is used to receive more 
frames. 
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--@ CLOSE RX eeu command should not be used when the SCC2 is in Ethernet 
mode. 


INIT RX PARAMETERS—This command initializes all the receive parameters in this 

serial channel parameter RAM to their reset state and should only be issued when the 
_receiver is disabled. The INIT TX AND RX PARAMS command can also be used to © 
_ reset the receive and transmit parameters. 


rer PPA AF Sm me oe ow om ml Ln _ of ine 04 Lita 


* SE! UNVUP ADDRESS—T niS COmimand iS USEC tO Séi a Dit if ONE OF 
four individual/group address hash filter registers. The i naividua | or group addre an be 
added to the hash table should be written to TADDR_L, TADDR_M, and TADDR_H in 
the parameter RAM before executing this command. The RISC microcontroller checks 

_ the I/G bit in the address stored in TADDR to determine whether to use the individual 

~ hash table or the group hash table. A zero in the 1/G bit implies an individual address 
and a 1 in the I/G bit implies a group address. This command can be executed at any 
time, regardless of whether the Ethernet channel is enabled. 


If you need to delete an address from the hash table, disable the Ethernet channel, 
clear the hash table registers, and execute this command for the remaining addresses. 
You must do this because the hash table might have mapped multiple addresses to the 
same hash table bit. 


16.9.22.10 SCC2 ETHERNET ADDRESS RECOGNITION. The SCC2 Ethernet controller 
can filter the received frames based on different addressing types—physical (individual), 
group (multicast), broadcast (all-ones group address), and promiscuous. You can set the 
promiscuous address type in the PSMR-—SCC2 Ethernet register. The difference between 
an individual address and a group address is determined by the I/G bit in the destination 


address field, which is part of the standard Ethernet protocol. A flowchart for address 


recognition on received frames is illustrated in Figure 16-106. 


In the physical type of address recognition, the SCC2 Ethernet controller compares the 
destination address field of the received frame with the physical address that you program 
in PADDR1_H, PADDR1_M, and PADDR1_L. You can also perform address recognition on 
multiple individual addresses using the IADDR1—4 hash table. 
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Figure 16-106. Ethernet Address Recognition Flowchart 
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In the group type of address recognition, the SCC2 Ethernet controller determines whether 
or not the group address is a broadcast address. If broadcast addresses are enabled, then 
the frame is accepted, but if the group address is not a broadcast address, then you can 
perform address recognition on multiple group addresses using the GADDR1—4 hash table. 
In promiscuous mode, the SCC2 Ethernet controller receives all the incoming frames 
regardless of their address. 


16.9.22.11 HASH TABLE ALGORITHM. Individual and group hash filtering can be 
operated using a certain process. The SCC2 Ethernet controller maps any 48-bit address 
into one of 64 bins, which are represented by 64 bits stored in GADDR1—4 or IADDR1-4. 
When the SET GROUP ADDRESS command is executed, the SCC2 Ethernet controller 
maps the selected 48-bit address into one of the 64 bits by passing the 48-bit address 
through the on-chip 32-bit CRC generator and selecting 6 bits of the CRC-encoded result to 
generate a number between 1 and 64. Bits 31-30 of the CRC result select one of the four 
GADDRs or IADDRs and bits 29-26 of the CRC result select the bit within the selected 
register. 


When the SCC2 Ethernet controller receives a frame, the same process is used. If the CRC 
generator selects a bit that is set in the group/individual hash table, the frame is accepted. 
Otherwise, it is rejected. The result is that if eight group addresses are stored in the hash 
table and random group addresses are received, the hash table prevents roughly 56/64 
(87.5%) of the group address frames from reaching memory. Those that do reach memory 
must be further filtered by the processor to determine if they truly contain one of the eight 
preferred addresses. | 


Better performance is achieved by using the group and individual hash tables 
simultaneously. For instance, if eight group and eight physical addresses are stored in their 
respective hash tables, 87.5% of all frames are prevented from reaching memory. The 
effectiveness of the hash table declines as the number of addresses increases. For 
instance, with 128 addresses stored in a 64-bin hash table, the vast majority of the hash 
table bits are set, thus preventing a small fraction of the frames from reaching memory. 


Note: The hash tables cannot be used to reject frames that match a set of entered 
addresses because unintended addresses are matched to the same bit in the 
hash table. | 
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16.9.22.12 INTERPACKET GAP TIME. The minimum interpacket gap time for 
back-to-back transmission is 9.6us. The receiver receives back-to-back frames with this 
minimum spacing. In addition, after the backoff algorithm, the transmitter waits for carrier 
sense to be negated before retransmitting the frame. Retransmission begins 9.6us after 
Carrier sense is negated if it stays negated for at least 6.4us. 


16.9.22.13 HANDLING COLLISIONS. If a collision occurs while a frame is being 
transmitted, the SCC2 Ethernet controller continues transmitting for at least 32 bit times, 
thus transmitting a JAM pattern that consists of 32 ones. If the collision occurs during the 
preamble sequence, the JAM pattern will be sent at the end of the preamble sequence. 


If a collision occurs within 64 byte times, the retry process is initiated. The transmitter waits 
a random number of slot times (512 bit times or 52us). If a collision occurs after 64 byte 
times, then no retransmission is performed and the buffer is closed with an LC error 
indication. If a collision occurs while a frame is being received, reception stops. This error is 
only reported in the buffer descriptor if the length of this frame is greater than or equal to the 
MINFLR or if the RSH mode is enabled in the PSMR-—SCC2 Ethernet. 


16.9.22.14 LOOPBACK AND FULL-DUPLEX OPERATION. Both internal and external 
loopback is supported by the SCC2 Ethernet controller. In loopback mode, both of the SCC2 
FIFOs are used and the channel actually operates in a full-duplex fashion. Both internal and 
external loopback are configured using combinations of the LPB bit in the PSMR-SCC2 
Ethernet and the DIAG field in the GSMR_L. 


Internal loopback disconnects the serial communication controller from the serial interface. 
The receive data is connected to the transmit data and the receive clock is connected to the 
transmit clock. Both FIFOs are used. The transmitted data from the transmit FIFO is 
received immediately into the receive FIFO. There is no heartbeat check in this mode. TENA 
should be configured as a general-purpose output, and the HBC bit in the PSMR-SCC2 
Ethernet should be zero. | 


In external loopback operation, the SCC2 Ethernet controller listens for data being received 
from the EEST at the same time that it is transmitting. 
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Communication Processor Module 


16.9.22.15 SCC2 ETHERNET CONTROLLER ERRORS. The SCC2 Ethernet controller 
reports frame reception and transmission error conditions using the channel buffer 
descriptors, the error counters, and the SCCE-—Ethernet register. The following transmission 
errors can be detected by the SCC2 Ethernet controller. 


Transmitter Underrun Error—lf this error occurs, the channel sends 32 bits that ensures 
a CRC error, stops transmitting the buffer, closes it, sets the UN bit in the TX buffer 


Fe ae a om se 


transmission after it receives the RESTART TRANSMIT command. 


Carrier Sense Lost During Frame Transmission Error—When this error occurs and no 
collision is found in the frame, the channel sets the CSL bit in the TX buffer descriptor, 
sets the TXE in the SCCE—Ethernet register, and continues the buffer transmission as 
normal. No retries are performed after this error occurs. 


Retransmission Attempts Limit Expired Error—When this error occurs, the channel 
stops transmitting the buffer, closes it, sets the RL bit in the TX buffer descriptor, and 
sets TXE. The channel resumes transmission after it receives the RESTART 
TRANSMIT command. 


Late Collision Error—When this error occurs, the channel stops transmitting the buffer, 
closes it, sets the LC bit in the TX buffer descriptor, and sets TXE. The channel resumes 
transmission after it receives the RESTART TRANSMIT command. This error is 
discussed further in the definition of the LCW bit in the PSMR—SCC2 Ethernet. 


Heartbeat Error—Some transceivers have a self-test feature called “heartbeat” or 
“signal quality error.” To signify a good self-test, the transceiver indicates a collision to 
the MPC823 within 20 clocks after the Ethernet controller transmits a frame. This 
indication does not imply a real collision error on the network, but is rather an indication 
that the transceiver still seems to be functioning properly. This is called the heartbeat 
condition. 


If the HBC bit is set in the PSMR-—SCC2 Ethernet and the MPC823 does not detect a 
heartbeat condition after transmitting a frame, then a heartbeat error occurs. In which 
case, the channel closes the buffer, sets the HB bit in the TX buffer descriptor, and 
generates the TXE interrupt if it is enabled. 


The following reception errors can be detected by the SCC2 Ethernet controller: 


Overrun Error—The SCC2 Ethernet controller maintains an internal FIFO for receiving 
data. If a receiver FIFO overrun occurs, the channel writes the received data byte to the 
internal FIFO over the previously received byte. The previous data byte and frame 
status are lost. The channel closes the buffer, sets the OV bit in the RX buffer 
descriptor, RXF in the SCCE-Ethernet register, and increments the discarded frame 
counter. The receiver then enters hunt mode. 


Busy Error—This error occurs when a frame has been received and discarded because 
of a lack of buffers. The channel sets the BSY bit in the SCCE—Ethernet register and 
increments the discarded frame counter. 
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e Non-Octet Error (Dribbling Bits)—The SCC2 Ethernet controller handles up to seven 
dribbling bits when the receive frame terminates nonoctet aligned and it checks the 
CRC of the frame on the last octet boundary. If there is a CRC error, then the frame 
nonoctet aligned error is reported, the RXF bit is set, and the alignment error counter is 
incremented. If there is no CRC error, then no error is reported. 


e CRC Error—When a CRC error occurs, the channel closes the buffer, sets the CR bit 
in the RX buffer descriptor, and the RXF bit in the SCCE—Ethernet register. The channel 
also increments the CRC error counter (CRCEC). After receiving a frame with a CRC 
error, the receiver enters hunt mode. CRC checking cannot be disabled, but the CRC 
error can be ignored if checking is not required. 


16.9.23 Programming the SCC2 Ethernet Controller 


16.9.23.1 SCC2 ETHERNET MODE REGISTER. When the SCC2 is in Ethernet mode, the 
16-bit, memory-mapped, read/write protocol-specific mode register is referred to as the 
SCC2 Ethernet mode register (PSMR-—SCC2 Ethernet). Since each protocol has specific 
requirements, the PSMR bits are different for each implementation. 


PSMR-SCC2 ETHERNET 


BRO | SBT | LPB | RES ——— 


[onc [eno 
refelele, » Jefofolole[e] «Jo 
raw [rw few [aw [aw [Aw | aw [aw aw few Paw | AW 


(IMMR & OxFFFF0000) + 0xA28 





HBC—Heartbeat Checking 
0 = No heartbeat checking is performed. Do not wait for a collision after transmission. 
1 = Wait 20 transmit clocks or 2us for a collision asserted by the transceiver after 
transmission. The HB bit in the TX buffer descriptor is set if the heartbeat is not 
heard within 20 transmit clocks. 


FC—Force Collision 

O = Normal operation. 

1 = The channel forces a collision when each frame is transmitted. The MPC823 
should be configured in loopback operation when using this feature so that you can 
test the collision logic. In the end, the retry limit for each transmit frame is 
exceeded. 


RSH—Receive Short Frames 


O = Discard short frames that are not as long as MINFLR. 
1 = Receive short frames. 
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Communication Processor Module 


|[AM—lIndividual Address Mode 


O= Normal operation. A single 48-bit physical address that is stored in PADDR1_x is 
checked when it is received. 

1 = The individual hash table is used to check all individual addresses that are 
received. 


‘CRC—CRC Selection 


- 00 = Reserved. 
01 = Reserved. 
10 = 32-bit CCITT-CRC (Ethernet). X32 + X26 + X23 + X22 + X16 + X12 + X11 + X10 
+ X8 + X7 + X5 + X4+ X2 + X1 +1. Select this to comply with Ethernet 
specifications. 
11 = Reserved. 


PRO—Promiscuous 


O= Check the destination address of the incoming frames. 
= Receive the frame regardless of its address. 


BRO—Broadcast Address 


0 = Receive all frames containing the broadcast address. 
1 = Reject all frames containing the broadcast address, unless the PRO bit = 1. 


SBT—Stop Backoff Timer 


O= The backoff timer is functioning normally. 

1 = The backoff timer for the random wait after a collision is sans when carrier 
sense is active. This method makes the retransmission less aggressive than the 
maximum allowed in the IEEE 802.3 standard. The persistence (P_Per) parameter 
in the parameter RAM can be used in combination with, or in place of, the SBT bit. 


LPB—Loopback Operation 


O = Normal operation. 

1 = The channel is configured into internal or external loopback operation as 
determined by the DIAG field of the GSMR_L. For external loopback, the DIAG 
field should be configured for normal operation and for internal loopback they 
should be configured for loopback operation. 


Bit 10—Reserved 
This bit is reserved and should be set to O. 


_LCW—Late Collision Window 


0 = A late collision is any collision that occurs at least 64 bytes from the preamble. 
1 = A late collision is any collision that occurs at least 56 bytes from the preamble. 
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NIB—Number of Ignored Bits 


This parameter determines how soon after RENA assertion the SCC2 Ethernet controller 
should begin looking for the start frame delimiter. In most situations, you should select 22 
bits. 


000 = Begin searching for the SFD 13 bits after the assertion of RENA. 

001 = Begin searching for the SFD 14 bits after the assertion of RENA. 

010 = Begin searching for the SFD 15 bits after the assertion of RENA. 

011 = Begin searching for the SFD 16 bits after the assertion of RENA. 
100 = Begin searching for the SFD 21 bits after the assertion of RENA. fom 
101 = Begin searching for the SFD 22 bits after the assertion of RENA. 
110 = Begin searching for the SFD 23 bits after the assertion of RENA. Nas 
111 = Begin searching for the SFD 24 bits after the assertion of RENA. 


FDE—Full-Duplex Ethernet 


O = Disable full-duplex Ethernet mode. 
1 = Enable full-duplex Ethernet mode. 


Note: When this bit is set to 1, you must also set the LPB bit to 1. 
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16.9.23.2 SCC2 ETHERNET RECEIVE BUFFER DESCRIPTOR. The SCC2 Ethernet 
controller uses the receive (RX) buffer descriptor to report information about the received 
data for each buffer. Figure 16-107 illustrates an Ethernet receive buffer descriptor example. 


MRBLR = 64 BYTES FOR THIS SCC 


BUFFER 


RECEIVE BD 0 
: a: FrEn 


DEST ADDRESS (6) 
SOURCE ADDRESS (6) 










STATUS 


































LENGTH see TYPE/LENGTH (2) sive 
FULL 
POINTER DATA BYTES (50) 
BUFFER ee 
STATUS CRC BYTES (4) 
CLOSED AFTER 
POINTER 32-BIT BUFFER POINTER CRC 
RECEIVED. 
OPTIONAL TAG 
BYTE 
: RECEIVE BD 2 APPENDED BUFFER _ 
COLLIDED FRAME WILL 
BE OVERWRITTEN. 
LENGTH 64 BYTES 
COLLISION 
POINTER 32-BIT BUFFER POINTER Ore eu 





REUSED 


RECEIVE BD 3 
E 
XXXX BUFFER 64 BYTES 


STILL 
EMPTY 


BUFFER 


STATUS 









LENGTH 


POINTER 32-BIT BUFFER POINTER 


LINE IDLE 


NON-COLLIDED ETHERNET FRAME 1 






TWO FRAMES PRESENT 
RECEIVED IN ETHERNET TIME 
TIME ——> COLLISION 


Figure 16-107. Ethernet Receive Buffer Descriptor Example 
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RX DATA BUFFER POINTER 









or A Note: The communication processor module sets all the status bits in this buffer 

i descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 


E—Empty 

O= The data buffer associated with this RX buffer descriptor has been filled with data 
or has stopped receiving data because an error occurred. The core is free to 
examine or write to any fields of this RX buffer descriptor. The communication 
processor module does not use this buffer descriptor as long as the E bit is zero. 

1 = The data buffer associated with this RX buffer descriptor is empty or is currently 
receiving data. This RX buffer descriptor and its associated receive buffer are 
owned by the communication processor module. Once the E bit is set, the core 
should not write any fields of this RX buffer descriptor. 


Bits 1,6, and 8—-9—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Buffer Descriptor in Table) 

0 = This is not the last buffer descriptor in the RX buffer descriptor table. 

1 = This is the last buffer descriptor in the RX buffer descriptor table. After this buffer 
is used, the communication processor module receives incoming data into the first 
buffer descriptor that RBASE points to in the table. The number of RX buffer 
descriptors in this table is programmable and determined only by the W bit and 
overall space constraints of the dual-port RAM. 


I—Interrupt 


O = No interrupt is generated after this buffer is used. 
= The RXB or RXF bit of the SCCE-—Ethernet register is set when this buffer is used 
by the SCC2 Ethernet controller. These two bits can cause interrupts if they are 
enabled. 
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Communication Processor Module 


L—Last in Frame 
The Ethernet controller sets this bit when this buffer is the last one in a frame. If the end of 
a frame is reached or an error is received, one or more of the CL, OV, CR, SH, NO, and LG 


bits are set. The SCC2 Ethernet controller writes the number of frame octets to the DATA 
LENGTH field. | 


O= The buffer is not the last one in a frame. 
1 = The buffer is the last one in a frame. 


F—First in Frame 
The SCC2 Ethernet controller sets this bit when this buffer is the first one in a frame. 


O= The buffer is not the first one in a frame. 
1 = The buffer is the first one in a frame. 


M—Miss 


The SCC2 Ethernet controller sets this bit for frames that are accepted in promiscuous 
mode, but are flagged as a “miss” by the internal address recognition. Thus, while in 
promiscuous mode, you can use the this bit to determine whether the frame is destined to 
this station. This bit is valid only if the L bit is set. 


O= The frame is received because of an address recognition hit. 
1 = The frame is received because of promiscuous mode. 


LG—RX Frame Length Violation 


This bit indicates that a frame length greater than the maximum defined for this channel has 
been recognized. Only the maximum-allowed number of bytes is written to the data buffer. 


'NO—RX Nonoctet Aligned Frame 


This bit indicates that a frame containing a number of bits not divisible by eight is received. 
Also, the CRC check that occurs at the preceding byte boundary has generated an error. 


SH—Short Frame 


This bit indicates that a frame length less than the minimum defined for this channel has 
been recognized. This can only happen if the RSH bit is set in the PSMR-SCC2 Ethernet. 


CR—RX CRC Error 
This bit indicates that this frame contains a CRC error. 


OV—Overrun 
This bit indicates that a receiver overrun has occurred during frame reception. 


CL—Collision 


This bit indicates that this frame is closed because a collision has occurred during frame 
reception. This bit is only set if a late collision occurs or if the RSH bit is enabled in the 
PSMR-SCC2 Ethernet. Late collisions are better defined in the LCW bit of the same 
register. 
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DATA LENGTH 


These bits represent the number of octets the communication processor module writes into 
this buffer descriptor data buffer. It is written by the communication processor module once 
the buffer is closed. When this buffer descriptor is the last buffer descriptor in the frame, the 
DATA LENGTH contains the total number of frame octets (including four bytes for CRC). 


| wy 4 Note: The actual amount of memory allocated for this buffer should be greater than or 
| equal to the contents of the MRBLR. 


RX DATA BUFFER POINTER ( 3 


These bits always point to the first location of the associated data buffer, can reside in 
internal or external memory, and must be divisible by four. 


16.9.23.3 SCC2 ETHERNET TRANSMIT BUFFER DESCRIPTOR. Data is sent to the 
SCC2 Ethernet controller for transmission on an SCC2 channel by arranging it in buffers 
referenced by the channel’s transmit (TX) buffer descriptor table. Using the buffer 
descriptors, the SCC2 Ethernet controller confirms transmission or indicates error 
conditions so that the core knows the buffers have been serviced. 
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TX DATA BUFFER POINTER 


NOTE: You are only responsible for initializing the items in bold. 






"O Note: The communication processor module sets all the status bits in this buffer 

. descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 
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R—Ready 
O= The data buffer associated with this buffer descriptor is not ready for transmission 
- and you are free to manipulate this buffer descriptor or its associated data buffer. 
The communication processor module clears this bit after the buffer has been 
_ transmitted or after an error condition is encountered. 
1 = The data buffer, which you have prepared for transmission, has not been 
- transmitted or is currently being transmitted. You cannot write any fields of this 
buffer descriptor once this bit is set. 


PAD—Short Frame Padding 
This bit is only valid when the L bit is set. Otherwise, it is ignored. 


0 = Do not add pads to short frames. 
1 = Add pads to short frames. Pad bytes are inserted until the length of the transmitted 
_ frame equals the MINFLR and they are stored in pads in the parameter RAM. 


W—Wrap (Final Buffer Descriptor in Table) 


Q= This is not the last buffer descriptor in the TX buffer descriptor table. 

1 = This is the last buffer descriptor in the TX buffer descriptor table. After this buffer is 
used, the communication processor module receives incoming data into the first 
buffer descriptor that TBASE points to in the table. The number of TX buffer 
descriptors in this table is programmable and determined only by the W bit and 
overall space constraints of the dual-port RAM. 


ag Note: The TX buffer descriptor table must contain more than one buffer descriptor in 
| SCC2 Ethernet mode. , 


|—Interrupt 
O = No interrupt is generated after this buffer is serviced. 
1 = The TXB or TXE bit is set in the SCCE—Ethernet register after this buffer is 
serviced. These bits can cause interrupts if they are enabled. 


L—Last 
0 = This is not the last buffer in the transmit frame. 
1 = This is the last buffer in the transmit frame. 


TC—TX CRO 
This bit is valid only when the L bit is set. Otherwise, it is ignored. 


O = End transmission immediately after the last data byte. 
1 = Transmit the CRC sequence after the last data byte. 
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DEF—Defer Indication 


This bit indicates that this frame had a collision before it was sent. It is useful for channel 
statistics. The SCC2 Ethernet controller writes this bit after it finishes transmitting the 
associated data buffer. 


HB—Heartbeat 
This bit indicates the collision input was not asserted within 20 transmit clocks after 
transmission. It cannot be set unless the HBC bit is set in the PSMR—SCC2 Ethernet. The 


SCC2 Ethernet controller writes this bit after it finishes transmitting the associated data 
buffer. | 


|_C—tLate Collision 


This bit indicates that a collision occurred after the number of bytes defined for the LCW bit 
in the PSMR-SCC2 Ethernet are transmitted. The SCC2 Ethernet controller stops 
transmitting and writes this bit after it finishes transmitting the associated data buffer. 


RL—Retransmission Limit 


This bit indicates when the transmitter fails Retry Limit + 1 attempts to successfully transmit 
a message because of repeated collisions on the medium. The SCC2 Ethernet controller 
writes this bit after it finishes transmitting the associated data buffer. 


RC—Retry Count 


These bits indicate the number of retries required before this frame is successfully 
transmitted. If RC = 0, then the frame is transmitted correctly the first time. If RC = 15 and 
RET_Lim = 15 in the parameter RAM, then 15 retries are required. If RC = 15 and 
RET_Lim > 15 in the parameter RAM, then 15 or more retries are required. The SCC2 
Ethernet controller writes these bits after it finishes transmitting the associated data buffer. 


UN—Underrun 


This bit indicates that the SCC2 Ethernet controller has encountered a transmitter underrun 
condition while transmitting the associated data buffer. The SCC2 Ethernet controller writes 
this bit after it finishes transmitting the associated data buffer. 


CSL—Carrier Sense Lost 


This bit indicates that the carrier sense was lost during frame transmission. The SCC2 
Ethernet controller writes this bit after it finishes transmitting the associated data buffer. 


DATA LENGTH 


This field represents the number of octets the SCC2 Ethernet controller should transmit from 
this buffer descriptor data buffer. It is never modified by the communication processor 
module. The value of this field should be greater than zero. The SCC2 Ethernet controller 
writes these bits after it finishes transmitting the associated data buffer. 


TX DATA BUFFER POINTER 


This field contains the address of the associated data buffer, can be even or odd, and reside 
in internal or external memory. This value is never modified by the communication processor 
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Communication Processor Module 


module. The SCC2 Ethernet controller writes these bits after it finishes transmitting the 
associated data buffer. 


16.9.23.4 SCC2 ETHERNET EVENT REGISTER. When the SCC2 is in Ethernet mode, 
the 16-bit memory-mapped SCC2 event register is referred to as the SCC2 Ethernet event 
register (SCCE-—Ethernet). Since each protocol has specific requirements, the SCCE bits 
are different for each implementation. This register is used to generate interrupts and report 
evenis recognized by ihe Eihernei channei. When an event is recognized, the SCC2 
Ethernet controller sets the corresponding bit in the SCCE—Ethernet register. Interrupts 
generated by this register can be masked in the SCCM-—Ethernet register. An example of 
interrupts that can be generated in the Ethernet protocol is illustrated in Figure 16-108. 


A bit is cleared by writing a 1(writing a zero has no effect) and more than one bit can be 
cleared at a time. All unmasked bits must be cleared before the communication processor 
module clears the internal interrupt request. This register is cleared at reset and can be read 
at any time. | 


SCCE-ETHERNET 


| RESERVED _ RESERVED | TXE 
RW 
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(IMMR & OxFFFFO000) + 0xA30 






Bits O—7 and 9—10—Reserved 
These bits are reserved and should be set to 0. 


GRA—Graceful Stop Complete 


This bit indicates that a graceful stop, initiated by the GRACEFUL STOP TRANSMIT 
command, is now complete. This bit is set as soon the transmitter finishes any frame that 
was in progress when the command was issued. It is set immediately if no frame was in 
progress when the command was issued. 


TXE—TX Error - 3 
This bit indicates that an error has occurred on the transmitter channel. 


RXF—RX Frame 
This bit indicates that a complete frame has been received on the Ethernet channel. 


BSY—Busy Condition 
This bit indicates when a frame is received and discarded due to a lack of buffers. 


TXB—TX Buffer 
This bit indicates that a buffer has been transmitted on the Ethernet channel. 
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RXB—RX Buffer 


This bit indicates that a buffer that was not a complete frame was received on the Ethernet 
channel. | 


FRAME 
RECEIVED IN ETHERNET 


STORED IN RX BUFFER 


Propalsafm 0 [on 


TIME ——> 












RXD LINE IDLE LINE IDLE 


RENA 


ETHERNET SCCE 
EVENTS RXB RXF 


NOTES: 
1. RXB event assumes receive buffers are 64 bytes each. 
2. The RENA events, if required, must be programmed in the port C parallel I/O, not in the SCC itself. 
3. The RXF interrupt may occur later than RENA due to receive FIFO latency. 


LEGEND: 
P = Preamble, SFD = Start Frame Delimiter, DA and SA = Source/Destination Address, T/L = Type/Length, 
D = Data, and CR = CRC bytes. 


FRAME STORED IN 
TRANSMITTED BY ETHERNET TX BUFFER 


TXD LINE IDLE | P]SFO|DAISAJTIL] =D — {CRI LINE IDLE 


wn a 
CLSN | 


HDLC SCCE 
TXB TXB 
EVENTS GRA 
NOTES: 


1. TXB events assume the frame required two transmit buffers. | 
2. The GRA event assumes a GRACEFUL STOP TRANSMIT command was issued during frame transmission. 
3. The TENA or CLSN events, if required, must be programmed in the port C parallel I/O, not in the SCC itself. 


Figure 16-108. Ethernet Interrupt Events Example 
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Communication Processor Module 


16.9.23.5 SCC2 ETHERNET MASK REGISTER. When the SCC2 is in Ethernet mode, the 
16-bit read/write SCC2 mask register is referred to as the SCC2 Ethernet mask register 
(SCCM-—Ethernet). Since each protocol has specific requirements, the SCCM bits are 
different for each implementation. This register has the same bit formats as the 
SCCE-Ethernet register. If a bit in the SCCM—Ethernet register is a 1, the corresponding 
interrupt in the SCCE—Ethernet register is enabled. If the bit is zero, the corresponding 
interrupt in the SCCE—Ethernet register is masked. 


SCCM-ETHERNET 


ee ee ee es oe See 


ee ee 
ee 


(IMMR & OxFFFFO000) + 0xA34 





16.9.23.6 SCC2 ETHERNET STATUS REGISTER. Since all Ethernet mode selections are 
in the GSMR_x and PSMR registers, the SCC2 Ethernet status register (SCCS—Ethernet) 
is not used when the SCC2 is in Ethernet mode. The current state of the RENA and CLSN 
signals can be found in port C. | 


16.9.23.7 SCC2 ETHERNET PROGRAMMING EXAMPLE. The following is an example 
initialization sequence for the SCC2 in Ethernet mode. The CLK1 pin is used for the Ethernet 
receiver and the CLK2 pin is used for the transmitter. 


1. Configure the port A pins to enable the TXD1 and RXD1 pins. Write PAPAR bits 12 
and 13 with ones, PADIR bits 12 and 13 with zeros, and PAODR bit 13 with zero. 


2. Configure the port C pins to enable CTS2 (CLSN) and CD2 (RENA). Write PCPAR and 
PCDIR bits 9 and 8 with zeros and PCSO bits 9 and 8 with ones. 


3. Donot enable the RTS2 (TENA) pin yet because the pin is still functioning as RTS and 
transmission on the LAN could accidentally begin. 


4. Configure port A to enable the CLK1 and CLK2 pins. Write PAPAR bits 7 and 6 with 
ones and PADIR bits 7 and 6 with zeros. 


5. Connect the CLK1 and CLK2 pins to SCC2 using the serial interface. Write the R2CS 
field in the SICR to 101 and the T2CS field to 100. 


6. Connect the SCC2 to the NMSI and clear the SC2 bit in the SICR. 
7. Initialize the SDMA configuration register (SDCR) to 0x0001. 


8. Write RBASE and TBASE in the SCC2 parameter RAM to point to the RX buffer 
descriptor and TX buffer descriptor in the dual-port RAM. Assuming one RX buffer 
descriptor at the beginning of the dual-port RAM and one TX buffer descriptor following 
that RX buffer descriptor, write RBASE with 0x2000 and TBASE with 0x2008. 


9. Program the CPCR to execute the INIT RX BD PARAMETER command for this 
channel. 
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10.Write RFCR and TFCR with 0x18 for normal operation. 


11.Write MRBLR with the maximum number of bytes per receive buffer. For this case, 
assume 1,520 bytes; so MRBLR = Ox05F0. In this example, the user wants to receive 
an entire frame into one buffer, so the MRBLR value is chosen to be the first value 
larger than 1,518 that is evenly divisible by four. 


12.Write C_PRES with OxFFFFFFFF to comply with 32-bit CCITT-CRC. 
13. Write C_MASK with 0xDEBB20E3 to comply with 32-bit CCITT-CRC. 
14.Clear CRCEC, ALEC, and DISFC for clarity. 
15.Write PAD with 0x8888 for the pad value. o 
16.Write RET_LIM with OxOOOF. | 3 
17.Write MFLR with OxO5EE to make the maximum frame size 1,518 bytes. 
18.Write MINFLR with 0x0040 to make the minimum frame size 64 bytes. 
19.Write MAXD1 and MAXD2 with OxO5EE to make the maximum DMA count 1,518 
bytes. 
20.Clear GADDR1—GADDR4. The group hash table is not used. 


21.Write PADDR1_H with 0x0380, PADDR1_M with 0x12E0, and PADDR1_L with 
0x5634 to configure the physical address 8003E0123456. 


22.Write P_Per with OxOO0O0. It is not used. 
23.Clear [|ADDR1—IADDR4. The individual hash table is not used. 
24.Clear TADDR_H, TADDR_M, and TADDRF_L for clarity. 


25. Initialize the RX buffer descriptor and assume the RX data buffer is at Ox00001000 in 
main memory. Write OxBO00 to Rx_BD_Status, 0x0000 t to Rx_BD_Length (optional), 
and 0x00001000 to Rx_BD_Pointer. 


26. Initialize the TX buffer descriptor and assume the TX data frame is at Ox00002000 in 
main memory and contains fourteen 8-bit characters (destination and source 
addresses plus the type field). Write OxFCOO.to Tx_BD_Status, add PAD to the frame 
and generate a CRC. Then write 0xO00D to Tx_BD_Length and 0x00002000 to 
Tx_BD_ Pointer. 


27.Write OxFFFF to the SCCE—Ethernet to clear any previous events. 

28.Write Ox001A to the SCCM-—Ethernet to enable the TXE, RXF, and TXB interrupts. 

29.Write 0Ox20000000 to the CIMR so that SCC2 can generate a system interrupt. The 
CICR should also be initialized. 

30. Write 0x00000000 to the GSMR_H to enable normal operation of all modes. 
31.Write 0x1088000C to the GSMR_L to configure the CTS (CLSN) and CD (RENA) pins 
to automatically control transmission and reception (DIAG field) and the Ethernet 

mode. TCI is set to allow more setup time for the EEST to receive the MPC823 
transmit data. TPL and TPP are set for Ethernet requirements. The DPLL is not used 


with Ethernet. Notice that the transmitter (ENT) and receiver (ENR) have not been 
enabled yet. 


32. Write 0xD555 to the DSR. 
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33.Set the PSMR-—SCC2 Ethernet to OxOA0A to configure 32-bit CRC, promiscuous mode 
and begin searching for the start frame delimiter 22 bits after RENA. 


34.Enable the TENA pin (RTS). Since the MODE field of the GSMR_L is written to 
Ethernet, the TENA signal is low. Write PCPAR bit 14 with a one and PCDIR bit 14 
with a zero. | 


35. Write 0x1088003C to the GSMR_L register to enable the SCC2 transmitter and 
receiver. This aaaitional write ensures that the ENT and EWN bits are enabled last. 


Note: After 14 bytes and the 46 bytes of automatic pad (plus the 4 bytes of CRC) are 
transmitted, the TX buffer descriptor is closed. Additionally, the receive buffer is 
closed after a frame is received. Any data received after 1,520 bytes or a single 
frame causes a busy (out-of-buffers) condition since only one RX buffer 
descriptor is prepared. 





16.10 UNIVERSAL SERIAL BUS CONTROLLER 


The universal serial bus (USB) is an industry standard extension to the PC architecture. The 
USB controller allows the MPC823 to exchange data with a PC host. It supports data 
exchanges between a host computer and a wide range of simultaneously accessible 
peripherals. The attached peripherals share USB bandwidth through a host scheduled 
token-based protocol. The USB physical interconnect is a tiered star topology. A hub is at 
the center of each star. Each wire segment is a point-to-point connection between the host 
and a hub or function or a hub connected to another hub/function. There is only one host in 
any USB system. The USB transfers signal and power over a four-wire cable. The signalling 
occurs over two wires and point-to-point segments. The USB full-speed signalling bit rate is 
12Mbps. A limited capability low-speed signalling mode is also defined at 1.5Mbps. 


The MPC823 USB controller consists of a transmitter module, receiver module, and two 
protocol state machines. The protocol state machines control the receiver and transmitter 
modules. One state machine implements the function state diagram and the other 
implements the host state diagram. The MPC823 USB controller is capable of implementing 
a USB function endpoint, a USB host, or both for testing purposes (loop-back diagnostics). 
Figure 16-109 illustrates the USB controller block diagram. 


For USB implementation, it is recommended that you get a copy of the USB Specification 
as a supplement to this manual. You can download a copy from http://www.usb.org. 


The USB transmitter contains four independent FIFOs, each containing 16 bytes. There is 
a dedicated FIFO for each of the four supported endpoints. The USB receiver has a single 
16-byte FIFO. When the USB controller is not enabled in the USMOD, it consumes minimal 
power. , 
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EXTERNAL TRANSCEIVER 


Figure 16-109. USB Controller Block Diagram 


16.10.1 Features 


The following list summarizes the USB slave mode features: 
e Supports USB slave mode 


e Four independent endpoints support control, bulk, interrupt and isochronous data 
transfers 


CRC16/CRC5 generation and checking 

NRZI encoding/decoding with bit stuffing 

12 or 1.5Mbps data rate 

Flexible data buffers with multiple buffers per frame 


Automatic retransmission upon transmit error 
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The following list summarizes the USB host controller features: 


e Supports control, bulk, interrupt, and isochronous data transfers 
¢ CRC16 generation and checking 

e NRZI encoding/decoding with bit stuffing 

e 12Mbps data rate 

e Flexible data buffers with multiple buffers per frame 





e Supports local loopback mode for diagnostics 


16.10.2 Host Controller Limitations 


The USB host controller only supports full-speed (12Mbps) USB devices. The transmitter 
does not support preamble generation for low-speed transmissions. The following tasks are 
not supported by the hardware and should be implemented by software: 


e CRC5 generation for token. Since CRC5 is calculated on 11 bits, this should not impose 
a large CPU overhead. 


e Retransmission after an error and error recovery. 
e¢ Generation and transmission of SOF token every 1ms. 


¢ Scheduling the various transfers within frame and between frames. The MPC823 USB 
host controller does not integrate the root hub. An external hub is required when more 
than one device is connected to the host. 


e The host controller programming model is very similar to the function endpoint 
programming model and does not conform to the Open Host Controller Interface 
(OHCl). Although Motorola plans to support full host functionality, our implementation 
will not be OHCI or UHCI (Universal Host Controller Interface) compatible. Those 
standards define the software programming model so that software drivers can be 
hardware-independent. Our implementation has a much more simplified software 
interface. 
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16.10.3 USB Controller Pin Functions and Clocking 


The USB controller interfaces to the USB through a differential line driver and receiver. The 
OE signal enables the line driver when the USB controller transmits on the bus. 


MPC823 USB q ia 
TRANSCEIVER 





Figure 16-110. USB Interface 


There are six I/O port pins associated with the USB port and their functionality is described in 
Table 16-31. Some transceivers may need additional control lines (speed select or 
low-power control), which can be supported by the general-purpose output lines. 
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Table 16-31. USB Pin Functionality 


PIN SYMBOL 


USBTXN, USBTXP 





” 





/O FUNCTION 


Outputs from the USB transmitter, inputs to the 
differential driver. 


RESULT 
single ended “0” 
logic “O” 
logic “1” 


Output Enable. Active low, enables the 
transceiver to transmit data on the bus. 


Receive Data. Input the USB receiver from the 


differential line receiver. 


Gated version of D+ and D-. Used to detect 
single-ended zero, and interconnect speed. 


RESULT 
single ended “0” 
full speed 
low speed 
n/a 


The USB controller accepts a reference clock that is four times the USB bit rate. This clock 
is programmed in the RiCS field of the serial interface clock register (SICR) and used by 
the DPLL circuitry to recover the bit rate clock. Refer to Section 16.7.5.3 Serial Interface 
Clock Route Register for more information. 


oe 4 Note: The MPC823 can run at different frequencies, but the USB reference clock must 
be four times the USB bit rate. The reference clock must be 48MHz for a 12Mb 
full-speed transfer or 6MHz for a 1.5Mb low-speed transfer. 
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16.10.4 Transmission and Reception Process 


After reset, the USB controller is addressable at the default address (0x00). During the 
enumeration process, the host assigns a unique address to the USB controller. The software 
should program the USB address register with the assigned address. The USB controller 
supports four independent endpoints, which can each be configured to support control, _ 
interrupt, bulk, or isochronous transfers modes when you program the USB endpoint ad 
registers. | | \ 3 





| wy Note: You must configure endpoint 0 as a control transfer type. This endpoint is used 
| by the USB system software as a control pipe and any additional control pipes 
may be provided by other endpoints. 


Once enabled, the USB controller looks for valid token packets. Tokens that are not valid 
(the PID or CRC check fails or the packet length is not 3 bytes) are ignored. 










ENUMERATION 
CESS 


UNENUMERATED 
| — PRO 





RECEIVE 


Figure 16-111. USB Controller Operating Modes 
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16.10.4.1 OUT TOKEN. When the USB controller receives an OUT token, data reception 
begins. The USB controller fetches the next buffer descriptor associated with the endpoint 
and if it is empty, it starts transferring the incoming packet to the buffer descriptor’s 
associated data buffer. When the data buffer has been filled, the USB controller clears the 
E bit in the buffer descriptor and generates an interrupt if the | bit in the buffer descriptor is 
set. If the incoming packet exceeds the length of the data buffer, the USB controller fetches 
the next buffer descriptor in the table and, if it is empty, continues transferring the rest of the 
packet to this buffer descriptor’s associated buffer. Otherwise, if it is full, an error occurs. The 
entire data packet, including the DATAO/DATA1 packet ID (PID), is written to the receive 
buffers and the PID is reflected in the PID field of the receive buffer descriptor. It is your 
responsibility to program the driver software to check data packet synchronization by 
monitoring the DATAO/DATA1 PID sequence toggle. 


Table 16-32. USB Out Token Reception 


DATA PACKET |. USEPx HANDSHAKE 
CORRUPTED RHS FIELD SENT TO HOST 


6 aang 
a 
[te 






oman | 
11 (STALL) STALL 


lf the packet was received error-free (no CRC errors and no bit stuff error), depending on 
the endpoint transfer mode configuration, an ACK handshake will be transmitted to the host. 
lf a reception error occurred, no handshake packet is returned, and the error status bits will 
be set in the last buffer descriptor associated with this packet. If the RHS field in the 
endpoint’s configuration register is programmed to respond with NAK, a NAK handshake is 
returned instead of ACK. If the RHS field is programmed to respond with STALL, a STALL 
handshake is returned. In both cases, the buffer will receive the data packet if the buffer 
descriptors are available. 
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16.10.4.2 IN TOKEN. To guarantee data transfer, the control software must preload the 
endpoint FIFO with a data packet prior to receiving an IN token. The software should set up 
the endpoint transmit buffer descriptor table and set the STR bit in the USB command 
register. The USB controller will fill the transmit FIFO and wait until it receives the IN token. 
Once it is received, transmission begins. 


Table 16-33. USB In Token Reception 


DATA PACKET USEPXx HANDSHAKE 
CORRUPTED THS FIELD SENT TO HOST 


ae a ae ee None (Data Discarded) 





00 (Normal) 


If data is not ready in the transmit FIFO or if the THS field in the endpoint’s configuration 
register is set to respond with NAK, a NAK handshake is returned. If the THS field in the 
endpoint’s configuration register is set to respond with STALL, a STALL handshake is 
returned. When the end of the current buffer descriptor has been reached and the last buffer 
in the packet bit is set, the CRC is appended. Following the transmission of a frame, the USB 
controller waits for a handshake packet, depending on the configuration of the endpoint. If 
the host fails to acknowledge the packet, the timeout status bit will be set in the buffer 
descriptor. It is your responsibility to program the driver software to set the proper 
DATAO/DATA1 PID in the transmitted packet. 3 





16.10.4.3 SETUP TOKEN. Setup transactions are similar in format to an OUT token, but 
you should use a SETUP rather than an OUT PID. A SETUP token is only recognized by an 
endpoint that is configured as a control endpoint. Once the SETUP token is received, setup 
data reception begins. The USB controller fetches the next buffer descriptor associated with 
the endpoint, and if it is empty, starts transferring the incoming packet to the buffer 
descriptor’s associated data buffer. When the data buffer has been filled, the USB controller 
clears the E bit in the buffer descriptor and generates an interrupt if the | bit in the buffer 
descriptor is set. If the incoming packet exceeds the length of the data buffer, the USB 
controller fetches the next buffer descriptor in the table and, if it is empty, continues 
transferring the rest of the packet to this buffer descriptor’s associated buffer. If it is full, an 
error occurs. The entire data packet including the DATAO PID are written to the receive 
buffers. If the packet was received error-free (no CRC errors and no bit stuff error) an ACK 
handshake will be transmitted to the host. If a reception error occurred, no handshake 
packet will be returned and the error status bits will be set in the last buffer descriptor 
associated with this packet. 
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16.10.4.4 SOF TOKEN. When a start of frame (SOF) token packet is received, the USB 
controller issues a SOF maskable interrupt and the frame number entry in the parameter 
RAM is updated. | 


16.10.4.5 PRE TOKEN. The PRE token signals the hub that a low-speed transaction is 
about to occur. The PRE token is only read by the hub. The USB controller ignores the PRE 


‘= token function in slave mode. In host mode, the USB controller cannot generate a PRE 
(oe! re pers 
ae. LONGI. 


16.10.5 USB Controller Parameter RAM Memory Map 


The USB controller parameter RAM area begins at the USB base address. The area is used 
for the general USB parameters. Notice that it is similar to the SCC2 general-purpose 
parameter RAM. 


Table 16-34. USB Parameter RAM Memory Map | 


[—rooness [wane [wom] _oescnrnow 
[iseiaseos | _eroetm | vatwos | __erdport Rept 
[ ussese+10 | FRAWEN | Farwoo | __FameNunmer 


. NOTE: You are only responsible for initializing the items in bold. | 
: USB Base = (IMMR & OxFFFFO000) + 0x3CO0. | 
All references to registers in the parameter RAM table are actually implemented in the dual-port RAM 
area as a memory-based register. 
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You must initialize certain parameter RAM values before the USB controller is enabled. 

Other values are initialized by the communication processor module. Once initialized, the 

parameter RAM values do not need to be accessed by your software. They should only be 

modified when no USB activity is in progress. | 


e EPxPTR—The endpoint parameters block pointers are index pointers to the endpoint’s pene 
parameter block. The parameter block can be allocated to any address divisible by 32 a 
in the dual-port RAM. The format of the endpoint parameter block is shown in 
Table 16-35. | 


EPxPTR 


fF seronrnostrowres fo fof of fo 





USB BASE + 0x00 (EPOPTR), 0x02 (EP1PTR), 0x04 (EP2PTR), 0x06 (EP3PTR) 


° FRAME_N—The frame number entry is updated by the USB controller when a SOF 
token is received. The entry contains 11 bits representing the frame number. An SOF 
interrupt is issued when this entry is updated. 


FRAME_N 







So 
| Vv | RESERVED FRAME NUMBER 
fw [ aw 


: USB BASE + 0x10 | 
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The V bit is set if the SOF token was received error-free. 


Table 16-35. Endpoint Parameters Block 


_ Half Word 
LIalf \ ral 


Al 










mase + O02 OM. dL SAND ee au vvOrG ; 


_ NOTE: You are only responsible for initializing the items in bold. Also, Base = (EP x PTR). 










e RBASE and TBASE—The receive and transmit buffer descriptor base address entries 
define the starting point in the dual-port RAM for the set of buffer descriptors to receive 
and transmit data. This provides a great deal of flexibility in how buffer descriptors for 
the USB controller are partitioned. By setting the W bit in the last buffer descriptor in 
each list, you can select how many buffer descriptors to allocate for the transmit and 
receive side of the USB controller. However, you must initialize these entries before 
enabling the USB controller. Furthermore, you should not configure buffer descriptor 
tables of the USB to overlap any other serial channel’s buffer descriptors or else erratic 
operation will occur. 


Note: RBASE and TBASE should contain a value that is divisible by 8. 
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e RFCR and TFCR—The USB function code registers control the value that you would 
like to appear on the AT pins when the associated SDMA channel accesses memory. 
It also controls the byte-ordering convention to be used in the transfers. 


RFCR AND TFCR 





Bits O-2—-Reserved | 
These bits are reserved and should be set to 0. 


BO—Byte Ordering 


Set this field to select the required byte ordering for the data buffer. If this field is 
modified on-the-fly, it will take effect at the beginning of the next frame. 


00= The DEC/Intel convention is used for byte ordering (swapped operation). It is 
also called little-endian byte ordering. The transmission order of bytes within 
a buffer word is reversed as compared to the Motorola mode. This mode is 
supported only for 32-bit port size memory. 

01 = PowerPC little-endian byte ordering. As data is transmitted onto the serial line 
from the data buffer, the least-significant byte of the buffer double-word 
contains data to be transmitted earlier than the most-significant byte of the 
same buffer double word. 

1X= Motorola byte ordering (normal operation). lt is also called big-endian byte 
ordering. As data is transmitted onto the serial line from the data buffer, the 
most-significant byte of the buffer word contains data to be transmitted earlier 
than the least-significant byte of the same buffer word. 


AT—Address Type 1-3 


This field contains the function code value used during this SDMA channel's memory 
accesses. ATO will be driven with a one to identify this SDMA channel access as a 
_ DMA-type access. 


e MRBLR—The maximum receive buffer length register defines the maximum number of 
bytes that the MPC823 will write to the USB receive buffer before moving to the next 
buffer. MRBLR must be divisible by 4. The MPC823 can write fewer bytes to the buffer 
than the MRBLR value if a condition such as an error or end-of-packet occurs, but it will 
never write more bytes than the MRBLR value. It follows, then, that buffers you supply 
to the MPC823 should always be at least as long as MRBLR. 


The transmit buffers for the USB channel are not affected in any way by the value 
programmed into MRBLR. Transmit buffers may be individually chosen to have varying 
lengths, as needed. The number of bytes to be transmitted is chosen by programming 
the DATA LENGTH field in the TX buffer descriptor. 
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Note: MRBLR is not intended to be changed dynamically while the USB channel is 
operating. However, if it is modified in a single bus cycle with one 16-bit move 
(not two 8-bit bus cycles back-to-back), then a dynamic change in the receive 
buffer length can be successfully achieved. This occurs when the 
communication processor module moves control to the next RX buffer descriptor 
in the table. Thus, a change to MRBLR will not have an immediate effect. To 
quarantee the exact RX buffer descriptor on which the change will occur, you 

should change MRBLR only while the USB receiver is disabled. 


(Srsii 


| 
\ 


¢ RBPTR—The receiver buffer descriptor pointer points to the next buffer descriptor that 
the receiver will transfer data to when it is in an idle state or to the current buffer 
descriptor while processing a frame. RBPTR should be initialized by the software after 
reset. When the end of the buffer descriptor table is reached, the communication 
processor module initializes this pointer to the value programmed in the RBASE entry. 
Although you never need to write RBPTR in most applications (except initialization), 
you can modify it when the receiver is disabled or when you are sure nal no receive 

_buffer is currently in use. 


e TBPTR—The transmitter buffer descriptor pointer for each USB endpoint points to the 
next buffer descriptor that the transmitter will transfer data from when it is in an idle state 

or to the current buffer descriptor during frame transmission. TBPTR should be 
initialized by the software after reset. When the end of buffer descriptor table is reached, 
the communication processor module initializes this pointer to the value programmed 
in the TBASE entry. Although you never need to write TBPTR in most applications 
(except initialization), you can modify it when the transmitter is disabled or when you 

~ are sure that no transmit buffer is currently in use. 


¢ TSTATE—The transmit internal state entry should be initilaized to zero before enabling 
the USB controller. : 


e Other General Parameters—These are the additional parameters listed in Table 16-34 
_ and Table 16-35. You do not need to access these parameters in normal operation and 
- they are only listed because they provide helpful information to experienced users for 
debugging purposes. The RX and TX internal data pointers (RPTR and TPTR) are 
updated by the SDMA channels to show the next address in the buffer to be accessed. 


TX internal byte count (TBCNT) is a down-count value that is initialized with the TX 
_buffer descriptors DATA LENGTH field and decremented with every byte read by the 
_~SDMA channels. RX internal byte count (RBCNT)is a down-count value that is 

initialized with the MRBLR value and decremented with every byte written by the SDMA 
channels. RSTATE, TSTATE, RTEMP, TTEMP, and the reserved areas are only used 

by the RISC microcontroller. 
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16.10.6 USB Commands 


You can program the CPM command register (CPCR) with the following commands to 
transmit data. 


USB COMMAND FORMAT ee 


Ea ee EEE Eee ee 


(IMMR & OxFFFF0000) + 0x9C0 





e RST—The reset bit is set by the core and cleared by the communication processor 
module and when this command is executed, RST and FLG are cleared within two 
general system clocks. The RISC microcontroller reset routine is approximately 60 
clocks long, but you can start initializing the communication processor module 
immediately after this command is issued. RST is useful when the core wants to reset 

_ the registers and parameters for all the channels as well as the RISC microprocessor 
and timer tables. However, this bit does not affect the serial interface or parallel I/O 
registers. 


e USBCMD—This field contains the USB command 


001 = The STOP TX ENDPOINT command disable the transmission of data on the 
selected endpoint. After you issue the command, flush the corresponding 
endpoint FIFO. No further transmissions will occur until the RESTART TX 
ENDPOINT command is issued. 

010 = The RESTART TX ENDPOINT command enables the transmission of data 
from the corresponding endpoint on the USB. This command is expected by 
the USB controller after a STOP TX ENDPOINT command or after a 
transmission error (underrun or timeout) occurs. 

O00 = Reserved. 

011 = Reserved. 

100 = Reserved. 

101 = Reserved. 

110 = Reserved. 

111 = Reserved. 


e ENDPOINT—This bit is the logical pipe number. 
00 =. Endpoint 0. 
O1= Endpoint 1. 
10 = Endpoint 2. 
11 = Endpoint 3. 
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e FLG—The bit is set by the core and cleared by the communication processor module. 


O= The communication processor module is ready to receive a new command. 

1= TheCPCR contains a command that the communication processor module is 
currently processing. The communication processor module clears this bit 
when the command finishes executing or after reset. 


For additional opcode information, see Table 16-2. 


16.10.7 USB Controller Errors 


The USB controller reports frame reception and transmission error conditions using the © 
channel buffer descriptors and the USB event register. The following transmission errors 
can be detected by the USB controller. 





e Transmit Underrun Error—lf this error occurs, the channel forces a bit-stuffing violation, 
terminates buffer transmission, closes the buffer, sets the UN bit in the TX buffer 
descriptor, and sets the corresponding TXE bit in the USB event register. The endpoint 
resumes transmission after the RESTART TX ENDPOINT command is received. 


e Transmit Timeout Error—lf this error occurs, the channel tries to retransmit if the RTE 
bit is set in the USB endpoint configuration register. If the RTE bit is not set or the 
second attempt fails, the channel closes the buffer, sets the TO bit in the TX buffer 
descriptor, and sets the corresponding TXEx bit in the USB event register. The endpoint 
resumes transmission after the RESTART TX ENDPOINT command is received. 


¢ TX Data Not Ready Error—This error occurs if an IN token was received, but the 
corresponding endpoint’s FIFO was empty, or if the endpoint was configured to NAK or 
STALL. The channel will set the TXEx bit in the USB event register. 


The following reception errors can be detected by the USB controller. 


e Overrun Error—The USB controller maintains an internal FIFO for receiving data. Ifa 
receive overrun occurs, the channel writes the received data byte to the internal FIFO 
over the previously received byte. The channel closes the buffer, sets the OV bit in the 
buffer descriptor, and sets the RXB bit in the USB event register. The NAK handshake 
is transmitted at the end of the received packet if the packet was error-free. 


° Busy Error—A frame was received and discarded due to a lack of buffers. The channel 
sets the BSY bit in the USB event register. | 


e Non Octet Aligned Packet Error—lf this error occurs, the channel writes the received 
data to the data buffer, closes the buffer, sets the NO bit in the RX buffer descriptor, and 
generates a RXB interrupt. 


e CRC Error—When a CRC error occurs, the channel closes the buffer, and sets the CR 
bit in the RX buffer descriptor and the RXB bit in the USB event register. In isochronous 
mode, the USB controller reports a CRC error, however, there are no handshake 
packets (ACK) and the transfer continues normally when an error occurs. 
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16.10.8 USB Controller Programming Model 


16.10.8.1 USB MODE REGISTER. The read/write USB mode (USMOD) register controls 
the USB controller's operation mode. 


USMOD 


Piss | resume | esenven | rest | wos | ev 


(IMMR & OxFFFFO000) + O0xA00 





LSS—Low-Speed Signaling | 
When set, this bit selects low-speed (1.5Mbps) signaling. The actual bit rate depends on the 
USB clock source. 


O= Full-speed (12Mbps) signaling. Normal operation mode. 
1 = Low-speed (1.5Mbps) signaling. This mode can be used for a point-to-point 
connection to a low-speed device or in local loopback mode. 


RESUME—Generate Resume Condition 


When set, this bit generates a resume condition on the USB. This bit should be used if the 
function wants to exit suspend mode. 


Bits 2—4—-Reserved 
These bits are reserved and should be set to zero. 


TEST—Test Mode 


O = Normal operation. 
1 = Local loopback mode. In this mode, if the HOST bit is set, endpoint 1 operates as 
host and endpoints 1-3 can be used as function endpoints. 


HOST—Host Mode 


O= The USB controller implements a USB function. 
1 = The USB controller implements a USB host. 
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Communication Processor Module 


EN—Enable USB 


This bit enables USB operation. When the EN bit is cleared, the USB is in a reset state and 
consumes minimal power. 


O = USB is disabled. 
1 = USB is enabled. 


Note: You should not modify any other bits of the USMOD register while the EN bit is 
‘set. 





16.10.8.2 USB RECEIVE BUFFER DESCRIPTOR. The USB controller reports 
information about each buffer of received data using (RX) buffer descriptors. The USB 
controller closes the current buffer, generates a maskable interrupt, and starts receiving 
data in the next buffer when the current buffer is full. Additionally, it will close the buffer under 
the following conditions: 


e When an end of packet is detected 
¢ When an overrun error occurs 
¢ When a bit stuff violation is detected — 


Note: The buffer descriptor’s status bits are sticky. Applications that operate on those 
bits may need to be reset after every relevant CPM transaction. 





The first word of the RX buffer descriptor contains status and control bits. You should 
prepare these bits before reception because they are set by the USB controller after the 
buffer has been closed. The second word contains the data length, in bytes, that was 
received. The third and fourth words contain a pointer that always points to the beginning of 
the received data buffer. 


rejeesfwli tule] es 


TX DATA BUFFER POINTER 


NOTE: You are only responsible for initializing the items in bold. 


16-358 ! MPC823 USER’S MANUAL MOTOROLA 


Communication Processor Module 


E—Empty 

O= The data buffer associated with this RX buffer descriptor has been filled with 
received data or data reception has been aborted due to an error condition. The 
core is free to examine or write to any fields of this RX buffer descriptor. The 
communication processor module will not use this buffer descriptor again when the 
E bit is zero. 

1 = The data buffer associated with this buffer descriptor is empty or reception is 
currently in progress. This RX buffer descriptor and its associated receive buffer 
are owned by the communication processor module. Once the E bit is set, the core 
should not write any fields to this RX buffer descriptor. | 


Bits 1, 9-10, and 15—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Buffer Descriptor in Table) 


0 = This is not the last buffer descriptor in the RX buffer descriptor table. 

1 = This is the last buffer descriptor in the RX buffer descriptor table. After this buffer 
is used, the communication processor module receives incoming data into the first 
buffer descriptor in the table (the buffer descriptor pointed to by RBASE). The 
number of RX buffer descriptors in this table is programmable and determined only 
by the W bit and the overall space constraints of the dual-port RAM. 


I—Interrupt 


O = No interrupt is generated after this buffer has been filled. 

1 = The RXB bit in the USB event register will be set when this buffer has been 
completely filled by the communication processor module, thus indicating the need 
for the core to process the buffer. The RXB bit can cause an interrupt if it is 
enabled. This bit is written by the USB controller after the received data has been 
placed into the associated data buffer. | 


|—Last 


This bit is set by the USB controller when the buffer is closed due to detection of 
end-of-packet condition on the bus or as a result of an error. This bit is written by the USB 
controller after the received data has been placed into the associated data buffer. 


0 = This buffer does not contain the last character of the message. 
1 = This buffer contains the last character of the message. 


F—First 

This bit is set by the USB controller when the buffer contains the first byte of a packet. This 
bit is written by the USB controller after the received data has been placed into the 
associated data buffer. 


0 = This buffer does not contain the first byte of the message. 
1 = This buffer contains the last byte of the message. 
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Communication Processor Module 


P|ID—Packet ID 


This field is set by the USB controller to indicate the type of the packet. It is only valid if the 
F bit is set. This field is written by the USB controller after the received data has been placed 
into the associated data buffer. 


00 = This buffer contains a DATAO packet. 
01 = This buffer contains a DATA1 packet. 


ANF PY em me em 


NO—RX Non Octet Aligned Packet 

This bit indicates that a packet containing a number of bits not exactly divisible by eight has 
been received. This bit is written by the USB controller after the received data has been 
placed into the associated data buffer. 


AB—Frame Aborted 


This bit indicates that a bit stuff error has occurred during reception. This bit is written by the 
USB controller after the received data has been placed into the associated data buffer. 


CR—CRC Error 


This bit indicates that a frame contains a CRC error. The received CRC bytes are always 
written to the receive buffer. This bit is written by the USB controller after the received data 
has been placed into the associated data buffer. 


OV—Overrun 


This bit indicates that a receiver overrun has occurred during reception. This bit is written by 
the USB controller after the received data has been placed into the associated data buffer. 


DATA LENGTH 


This field represents the number of octets that the communication processor module has 
written into this buffer descriptor’s data buffer. The communication processor module writes 
to this field when the buffer descriptor is closed. This bit is written by the USB controller after 
the received data has been placed into the associated data buffer. 


: Note: The actual amount of memory allocated for this buffer should be equal to the 

contents of the MRBLR, plus two CRC bytes that are included in the RX buffer. 
The USB device driver may strip out these two bytes before the data is sent to 
your application. 


RX DATA BUFFER POINTER 


This field always points to the first location of the associated data buffer and must be. 
divisible by four. The buffer may reside in either internal or external memory. This bit is 
written by the USB controller after the received data has been placed into ine associated 
data buffer. 


16-360 . MPC823 USER’S MANUAL _ MOTOROLA 


Communication Processor Module 


16.10.8.3 USB TRANSMIT BUFFER DESCRIPTOR. Data to be transmitted with the USB 
is presented to the communication processor module by arranging it in buffers referenced 
by the transmit (TX) buffer descriptor ring. The first word of the TX buffer ii a contains 
status and control bits. 








fem _| esac staf ro | un [es 


TX DATA BUFFER POINTER | 


NOTE: You are only responsible for initializing the items in bold. 







| “Oo Note: The communication processor module sets all the status bits in this buffer 

| descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the pay error 
bit is only set when a parity error occurs. 


R—Ready 

O= The data buffer associated with this buffer descriptor is not ready for transmission. 
You are free to manipulate this buffer descriptor or its associated data buffer. The 
communication processor module clears this bit after the buffer has been 
transmitted or after an error condition is encountered. 

1 = The data buffer, which you have prepared for transmission, has not been 
transmitted or is currently being transmitted. You cannot write to the fields of this 
buffer descriptor once this bit is set. 


Bits 1, 6-12, and 15—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Buffer Descriptor in Table) 


0 = This is not the last buffer descriptor in the TX buffer descriptor table. 

1 = This is the last buffer descriptor in the TX buffer descriptor table. After this buffer 
has been used, the communication processor module will transmit incoming data 
from the first buffer descriptor in the table (the buffer descriptor pointed to by 
TBASEx). The number of TX buffer descriptors in this table is programmable and 
is determined only by the W bit and the overall space constraints of the dual-port 
RAM. 
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I—Interrupt 


0 = No interrupt is generated after this buffer has been serviced. 
1 = The TXB or the appropriate TXEx bit in the USBER is set when this buffer is 
serviced. TXB and TXEx can cause interrupts if they are enabled. 


L—Last | | 
_ 0 This buffer does not contain the last character of the message. 
1 = This buffer contains the last character of the message. 


TC—Transmit CRC 
This bit is only valid when the L bit is set. Otherwise, it is ignored. 


O= Transmit end-of-packet after the last data byte. This setting can be used for testing 
purposes to send a bad CRC after the data. 
1 = Transmit the CRC sequence after the last data byte. 


CNF—Transmit Confirmation 
This bit is only valid when the L bit is set. Otherwise, it is ignored. 


0 = Continue to load the transmitter FIFO with the next packet. No handshake or 
response is expected from the function for this packet. 

1 = Wait for handshake or response from the function before stating the next packet or 
this is the last packet. 


Note: You cannot set CNF = 0 for a token that should be followed by.a data packet if 
the data packet buffer descriptor is not ready. — 





PiD—Packet ID 


This field is set by the USB Bentraller to indicate the type of the packet. It is only valid if the 
F bit is set. This field is written by the USB controller after the received data has been placed 
into the associated data buffer. 


NAK—NAK Handshake Received 


This bit indicates that the endpoint has responded with a NAK handshake. The ae was 
received error-free, however, the endpoint could not accept it. This bit is written by the USB 
controller after it has finished transmitting the associated data buffer. 


STAL—STALL Handshake Received 


This bit indicates that the endpoint has responded with a STALL handshake. The endpoint 
needs attention through the control pipe. This bit is written by the USB controller after it has 
finished transmitting the associated data buffer. 


TO—Time-Out 
This bit indicates that the endpoint has failed to acknowledge this packet. This bit is written 
by the USB controller after it has finished transmitting the associated data buffer. 
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UN—Underrun 


This bit indicates that the USB has encountered a transmitter underrun condition while 
transmitting the associated data buffer. This bit is written by the USB controller after it has 
finished transmitting the associated data buffer. 


DATA LENGTH 


This field represents the number of octets that the communication processor module should 
transmit from this buffer descriptor’s data buffer. It is never modified by the communication 
processor module. This value should normally be greater than zero. This bit is written by the 
USB controller after it has finished transmitting the associated data buffer. 


TX DATA BUFFER POINTER 


This field always points to the first location of the associated data buffer and it can be even 
or odd.The buffer can reside in either internal or external memory. This bit is written by the 
USB controller after it has finished transmitting the associated data buffer. | 


16.10.8.4 USB SLAVE ADDRESS REGISTER. The 8-bit, memory-mapped, read/write 
USB address register (USADR) holds the address for this USB port in slave mode. 


USADR 


(IMMR & OxFFFFO000) + OxA0t 





Bit O—Reserved 
This bit is reserved and should be set to 0. 


SAD—Slave Address 0-6 
This field contains the slave address for the USB port. 
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Communication Processor Module 


16.10.8.5 USB COMMAND REGISTER. The 8-bit, read/write USB command en 
register is used to at USB transmit operation in slave mode. 


USCOM 


(IMMR & OxFFFFO000) + OxA02 





STR—Start FIFO Fill 


When set, this bit causes the USB controller to start filling the corresponding endpoint 
transmit FIFO with data. Actual transmission will begin once the IN token for this endpoint 
is received. The STR bit is read aways as a zero. 


FLUSH—Flush FIFO 


When set, this bit causes the USB controller to flush the corresponding endpoint transmit 
FIFO. Before flushing the FIFO, you should issue the STOP TX ENDPOINT command. After 
flushing the FIFO you should issue the RESTART TX ENDPOINT command (see 

Section 16.10.6 USB Commands for more information). The FLUSH bit is always read as 
a zero. 


Bits 2—-5—Reserved 
These bits are reserved and should be set to zero. 


EP—Endpoint 
This field selects one of the four supported endpoints. 


16-364 MPC823 USER’S MANUAL MOTOROLA 


Communication Processor Module 


16.10.8.6 USB ENDPOINT REGISTERS 0-3. There are four 16-bit, memory-mapped, 
read/write USB endpoint configuration (USEPx) registers. 


USEPO-USEP3 





(IMMR & OxFFFFO000) + 0xA04 (USEPO), 0xA06 (USEP1), 0xA08 (USEP2), 0xAOA (USEP3) 


EPN— Endpoint Number 


This field defines the supported endpoint number. This field is oy used in slave mode and 
is ignored in host mode. | 


TM—tTransfer Mode 


00 = Control. 
01 = Interrupt. 
10 = Bulk. 


11 = Isochronous. 


MF—Enable Multi-Frame 


This bit allows loading of the next transmit packet into the FIFO before the previous packet 
finishes transmitting. This bit should be set to zero unless the endpoint is configured for ISO 
transfer mode. 


0 = The transmit FIFO can hold only one packet. 
1 = The transmit FIFO can hold more than one packet. 


RTE—Retransmit enable 
- This bit should be set to zero for an endpoint configured for ISO transfer mode. 


0 = No retransmission. 
1 = Automatic frame retransmission is enabled. The frame is retransmitted if transmit 
an error occurred (time-out). | 


Note: The RTE bit can only be set if the transmit packet is contained in a single buffer. 
Other wise, retransmission should be handled by software intervention. 
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THS—Transmit Handshake (Slave Mode Only) 
00 = Normal handshake. 
01 = Ignore IN token. 
10 = Force NAK handshake. Not allowed for control endpoint. 
11 = Force STALL handshake. Not allowed for control endpoint. 





2 | RHS—Receive Handshake (Slave Mode Only) 


er 00 = Normal handshake. 
01 = Ignore OUT token. 
10 = Force NAK handshake. Not allowed for control endpoint. 
11 = Force STALL handshake. Not allowed for control endpoint. 


16.10.8.7 USB BUFFER DESCRIPTOR RING. The data associated with the USB channel 
is stored in buffers that are referenced by buffer descriptors organized in buffer descriptor 
rings located in the dual-port RAM. These rings have the same basic configuration as those 
used by the serial communication controller and serial management controllers. There are 
four separate transmit buffer descriptor rings and four separate receive buffer descriptor 
rings for each endpoint, as illustrated in Figure 16-112. 


The buffer descriptor ring allows you to define buffers for transmission and buffers for 
reception. Each buffer descriptor ring forms a circular queue. The communication processor 
module confirms reception and transmission or indicates error conditions using the buffer 
descriptors to inform the processor that the buffers have been serviced. The actual buffers 
can reside in either external memory or internal memory. Data buffers can reside in the 
parameter RAM of a serial communication controller if it is not enabled. | 


38 
OF 
O= 
m 
nS: 
HO= 
oxo 
DD 
~5o > 
OS 
{ my F 
= 

m 





16-366 ~MPC823 USER’S MANUAL MOTOROLA 


DUAL- PORT RAM 


TX BUFFER DESCRIPTORS 


4 


DATA LENGTH 


DATA POINTER ane 


@ 
TX BUFFER DESCRIPTORS 


a“ 
FRAME STATUS : 


“ 
_ 





Ty 
\ 


FRAME STATUS 


DATA LENGTH 
DATA POINTER 





*< 
\ 
~ 
x 
N 


\ RX BUFFER DESCRIPTORS 








\ 


\ FRAME STATUS 


\ 
. DATA LENGTH 
\ 
\ 


DATA POINTER 


. 
\ ® 
\ @ 


RX BUFFER DESCRIPTORS 


TABLE POINTER 
EPO TX BD 
EP3 RX BD 
EP3 TX BD 





\ 
FRAME STATUS 


DATA LENGTH 


DATA POINTER 
\ 


\ 
\ 
\ 
\ 















Communication Processor Module 


‘EXTERNAL MEMORY 


TX DATA BUFFER 


TX DATA BUFFER 


RX DATA BUFFER 
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Figure 16-112. USB Buffer Descriptor Ring 
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16.10.8.8 USB EVENT REGISTER. The 16-bit, memory-mapped USB event register 
(USBER) is used to generate interrupt events and report events recognized by the USB 
channel. When an event is recognized, the USB sets the corresponding bit in the USBER. 
Interrupts generated by this register may be masked in the USBMR. A bit is cleared by 
writing a one (writing a zero has no effect) and more than one bit can be cleared at a time. 
All unmasked bits must be cleared before the communication processor module will clear 
the internal interrupt request. 


USBER 










RESERVED RESET | IDLE TXE3 | TXE2 TXE1 TXEO SOF BSY TXB RXB 
(IMMR & OXFFFFO000) + OXA10 . 


Bits 0O-5—Reserved | 
These bits are reserved and should be set to 0. 





RESET—Reset Condition Detected 
This bit indicates that the USB reset condition has been asserted. 


IDLE—IDLE Status Changed 


This bit indicates that a change in the status of the serial line was detected. The real time 
suspend status is reflected in the USBS register. 


TXEx—TX Error 


This bit indicates that an error occurred during transmission for endpoint x (packet not 
acknowledged or underrun). 


SOF—Start of Frame 


This bit indicates that a start-of-frame packet was received. ne packet is stored in the 
FRAME_N parameter RAM entry 


BSY—Busy Condition 


This bit indicates that received data has been discarded due to a lack of buffers. This bit is 
set after the first character is received for which there is no receive buffer available. 


TXB—TX Buffer 


This bit indicates that a buffer has been transmitted. It is set once the transmit data of the 
last character in the buffer was written to the transmit FIFO (if L=0) or after the last character 
was transmitted on the line (if L=1). 


RXB—RX Buffer 


This bit indicates that a buffer has been received. It is set after the last character has been 
written to the receive buffer and the RX buffer descriptor is closed. 
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16.10.8.9 USB MASK REGISTER. The 16-bit read/write USB mask register (USBMR) has 
the same bit formats as the USB event register. If a bit in the USBMR is one, the 
corresponding interrupt in the USBER is enabled. If the bit is zero, the corresponding 
interrupt in the USBER will be masked. 


USBMR 












RESERVED RESET} IDLE | TXE3 | TXE2 | TXE1 | TXEO sor | ssy | 1x8 | xe 
SE, es Ee ECE IES 
(IMMR & OXFFFFO000) + OXA14 


16.10.8.10 USB STATUS REGISTER. The 8-bit read-only USB status (USBS) register 
allows you to monitor real-time status condition on the USB lines. 






USBS 












RESERVED | IDLE 
(IMMR & OxFFFF0000) + 0xA17 


Bits O-6—Reserved 
These bits are reserved and should be set to 0. 





IDLE—Idle Status 


When set, this bit indicates that an idle condition has been detected on the USB lines. It is 
cleared when the bus is not idle. 


16.10.8.11 USB CONTROLLER INITIALIZATION EXAMPLE. The following is an 
example initialization sequence for the USB controller. It can be used to set up four function 
endpoints (0-3) to fill up transmit FIFOs so that data is ready for transmission when an IN 
token is received from the USB. You can generate the token by using a USB traffic 
generator. 


1. Write 0x00010000 to the BRGC1 register for division factor 1 to produce 4 48MHz, 
assuming the system clock is 48MHz. 


2. Clear the DR14 and DR15 bits of the PADIR and the DD14 and DD15 bits of ue 
PAPAR to select the USBRXD and USBOE pins. 


3. Clear the DR10 and DR11 bits of the PCDIR, the DD10 and DD11 bits of the PCPAR, 
and set the CD1 and CTS1 bits of the PCSO to select the USBRXP and USBRXN pins. 
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4. Set the DR6 and DR7 bits of the PCDIR and the DD6 and DD7 bits of the PCPAR to 
select the USBTXP and USBTXN pins. 


5. Write DPRAM+500 to the EPOPTR and DPRAM+520 to the EP1 PTR to set up the 
endpoint 0 and 1 pointers. 


6. Write DPRAM+540 to the EP2PTR and DPRAM+560 to the EP3PTR to set up the 
endpoint 2 and 3 pointers. 


ry AnA 


. Wiite 0xBC8&00004 to DPRAM+20 to set up the various status and DATA LENGTH 
fields of the endpoint 0 TX buffer descriptor. 


8. Write DPRAM+200 to DPRAM+24 to set up the TX DATA BUFFER POINTER field of 
the endpoint 0 TX buffer descriptor. 

9. Write BCCO00004 to DPRAM +28 to set up the status and DATA LENGTH fields of the 
endpoint 1 TX buffer descriptor. 

10. Write DPRAM+210 to DPRAM+2C to set up the DATA BUFFER POINTER field of the 
endpoint 1 TX buffer descriptor. — 

11.Write BC80004 to DPRAM+30 to set up the status and length fields of the endpoint 2 
TX buffer descriptor. 

12.Write DPRAM +220 to DPRAM+34 to set up the DATA BUFFER POINTER field of the 
endpoint 2 TX buffer descriptor. 

13.Write BCCO00004 to DPRAM+30 to set up the status and length fields of the endpoint 
3 TX buffer descriptor. 

14.Write DPRAM+30 to DPRAM+3C to set up the DATA BUFFER POINTER field of the 
endpoint 3 TX buffer descriptor. 

15.Write CAFECAFE to DPRAM+200 to set up the endpoint 0 TX data pattern. 

16.Write FACEFACE to DPRAM+210 to set up the endpoint 1 TX data pattern. 

17.Write BACEBACE to DPRAM+220 to set up the endpoint 2 TX data pattern. 

18.Write CaCeCaCe to DPRAM+230 to set up the endpoint 3 TX data pattern. 

19.Write 20002020 to DPRAM+500 to set ‘up the RBASE and TBASE fields of the 
endpoint 0 parameter RAM. 

20.Write 18180100 to DPRAM+504 to set up the RFCR and TFCR fields of the endpoint 
O parameter RAM. 

21.Write 20002020 to DPRAM+508 to set up the RBPTR and TBPTR fields of the » 
endpoint 0 parameter RAM. 

22.Clear the TSTATE field of the endpoint 0 parameter RAM. 

23.Write 20082028 to DPRAM+520 to set up the RBASE and TBASE fields of the 
endpoint 1 parameter RAM. 

24.Write 18180100 to DPRAM+524 to set up the RFCR and TFCR fields of the endpoint 
1 parameter RAM. 

25.Write 20082028 to DPRAM+528 to set up the RBPTR and TBPTR fields of the 
endpoint 1 parameter RAM. 


26. Clear the TSTATE field of the endpoint 1 satametet RAM. 


“J 
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27.Write 20102030 to DPRAM+540 to set up the RBASE and TBASE fields of the 
endpoint 2 parameter RAM. 


28.Write 18180100 to DPRAM+544 to set up the RFCR and TFCR fields of the endpoint 
2 parameter RAM. 


29. Write 20102030 to DPRAM+548 to set up the RBPTR and TBPTR fields of the fie 
endpoint 2 parameter RAM. eae 


30.Clear the TSTATE field of the endpoint 2 parameter RAM. 


31.Write 20182038 to DPRAM+560 to set up the RBASE and TBASE fields of the 
endpoint 3 parameter RAM. 


32.Write 18180100 to DPRAM+564 to set up the RFCR and TFCR fields of the endpoint | 
3 parameter RAM. | 


33. Write 20182038 to DPRAM+568 to set up the RBPTR and TBPTR fields of the 
endpoint 3 parameter RAM. 


34.Clear the TSTATE field of the endpoint 3 parameter RAM. 


35. Write 0x0200 to the USEPO for endpoint 0, bulk transfer, one packet only, and manual 
handshake. 


36. Write 0x1200 to the USEP1 for endpoint 1, bulk transfer, one packet only, and manual 
handshake. 


37.Write 0x2200 to the USEP2 for endpoint 2, bulk transfer, one packet only, and manual 
handshake. 


38. Write 0x3200 to the USEP3 for endpoint 3, bulk transfer, one packet only, and manual 
handshake. 


39. Write 0x00 to the USMOD for full-speed 12mps function endpoint mode and disable 
the USB. 


40. Write 0x05 to the USAD for slave address 5. 
41.Clear the USCOM register. 
42. Set the EN bit in the USMOD register to enable the USB controller. 


43. Write 0x80 to the USCOM to start filling the TX FIFO with endpoint 0 data ready for 
transmission when IN token is received. 


44.Write 0x81 to the USCOM to start filling the TX FIFO with endpoint 1 data ready for 
transmission when IN token is received. 


45.Write 0x82 to the USCOM to start filling the TX FIFO with endpoint 2 data ready for 
transmission when IN token is received. 


46.Write 0x83 to the USCOM to start filling the TX FIFO with endpoint 2 data ready for 
transmission when IN token is received. 
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16.11 THE SERIAL MANAGEMENT CONTROLLERS 


The serial management controllers (SMCs) consist of two full-duplex ports that can be 
independently configured to support any one of three protocols or modes—UART, 
Transparent, or general-circuit interface (GCI). Simple UART operation is used to provide a 
debug/monitor port in an application, which allows the serial communication controller to be 
free for other purposes. The serial management controller clock can be derived from one of 
the four internal baud rate generators or from a 16x external clock pin. 


The functionality and performance provided by the SMC in UART mode is generally less 
than that provided by the SCC2 in UART mode. The SMC implementation does not support 
such features as special character recognition and detection. 


In totally Transparent mode, the serial management controller can use the TDM channel to 
connect to a T1 line or directly to the SMC’s set of pins. However, SMC2 does not have its 
own set of dedicated pins, so the time-slot assigner pins are its only option. The receive and 
transmit clocks are derived from the time-division multiplex (TDM) channel, the internal baud 
rate generators, or from an external 1x clock. The Transparent protocol allows the 


‘transmitter and receiver to use the external synchronization pin. 


Each serial management controller supports the circuit interface and monitor channels of 


the GCI bus. In which case, the serial management controller is connected to a TDM 


_Channel in the serial interface. For testing purposes, the serial management controllers 


support loopback and echo modes. The SMC receiver and transmitter are double-buffered, 
which provides an effective FIFO size (latency) of two characters. Refer to 


Section 16.7 The Serial Interface with Time-Slot Assigner for details about conuguning 


the GCI interfaces. 


U-BUS 










SYNC 
CONTROL 
LOGIC  ;*< CLOCK 


CONTROL 
REGISTERS 
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Figure 16-113. Serial Management Controller Block Diagram 
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The receive data source for the two serial management controller channels have different 
pin options for each channel. SMC1 can either use the L1RXDA pin of the serial interface or 
the SMRXD1 pin if it is connected to the NMSI. SMC2 can also use the L1RXDA pin of the 
serial interface, but if you use the SMRXD2 pin the serial interface time-slot assigner 
function is not available. Likewise, the transmit data source for SMC1 can be the LITXDA 
pin if the serial management controller is connected to the TDM or the SMTXD1 pin if it is 
connected to the NMSI. SMC2 transmit data source can also be L1TXDA pin if the serial 
management controller is connected to the TDM, but if you use the SMTXD2 pin the serial 
interface time-slot assigner function is not available. 


lf the serial management controllers are connected to the TDM, the SMC receive and 
transmit clocks can be independent from each other, as defined in the CRTA bit of the 
SIMODE register. Refer to Section 16.7.5.2 Serial Interface Mode Register for more 
information. However, if the serial management controller is connected to the NMSI, the 
SMC receive and transmit clocks must be connected to a single clock source called SMCLK, 
which is an internal signal name for a clock that is generated from the bank of clocks. 
SMCLK originates from an external pin or one of the two internal baud rate generators. Refer 
to Section 16.7.8 Nonmultiplexed Serial Interface Configuration for more details. 


lf the serial management controllers are connected to the TDM, it gets its synchronization 
pulse from the time-slot assigner. Otherwise, if the serial management controller is 
connected to the NMSI and the Transparent protocol is selected, the serial management 
controller can use the SMSYNx pin as a synchronization pin to determine when it should 
start transmitting and receiving. The SMSYNx pin is not used when the serial 
communication controller is in UART mode. 


16.11.1 Features 


The following Is a list of the serial management controllers’ main features: 


e Each serial management controller can implement the UART protocol on its own pins 


e Each serial management controller can implement a totally Transparent protocol on a 
multiplexed or nonmultiplexed line. If SMC2 uses a nonmultiplexed line, the serial 
interface time-slot assigner is not available. 


e Each SMC channel fully supports the circuit interface and monitor channels of the GCI 
(IOM-2) in ISDN applications 


e Two serial management controllers support the two sets of circuit interface and monitor 
channels in the SCIT channels 0 and 1 


e Full-duplex operation 
e Local loopback and echo capability for testing 
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16.11.2 General SMC Mode Register 


The operating mode of each serial management controller port is defined by the 16-bit, 
memory-mapped, read/write general SMC mode register (SMCMR). Refer to each specific 
SMC protocol section for more information on this register and Table 16-2 for specific 
commands. | 


iG.ti.g OMG DUNE! DESCriptor Operation 


When the serial management controllers are configured to operate in GCI mode, their 
memory structure is predefined to be one half-word long for transmit and one half-word long 
for receive. For more information on these half-word structures, refer to 

Section 16.11.8 The SMC in GCI Mode. 


In UART and transparent modes, the serial management controllers have a memory 
structure that is like that of the serial communication controller. Each buffer is referenced by 
a buffer descriptor and organized in a buffer descriptor ring located in the dual-port RAM. 
Refer to Figure 16-114 for details. 


DUAL- PORT RAM | | EXTERNAL MEMORY 


>|  TXDATA BUFFER 
SMC RX BD RING 


RX DATA BUFFER 













FRAME STATUS 
DATA LENGTH 
DATA POINTER 


RX BD RING 


FRAME STATUS 
DATA LENGTH 
DATA POINTER 












POINTER TO SMCX » 
| TX BD RING 


Figure 16-114. SMC Memory Format 
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The buffer descriptor ring allows you to define buffers for transmission and reception and 

each ring forms a circular queue. Using the buffer descriptors, the communication processor oer eeen 
module confirms reception and transmission so that the processor knows the buffers have ( 

been serviced. The data buffers can reside in external or internal memory and the data 

buffers reside in the parameter area of an SCC2 or SMC if that channel is not enabled. | 


SHC 


16.11.4 SMC General Parameter RAM Memory Map 


Each SMC parameter RAM area begins at the same offset from each base. The 
protocol-specific portions of the SMC parameter RAM are discussed in each mode. The 
SMC general parameter RAM shared by the UART and transparent protocols is shown in 
Table 16-36. The GCI protocol has its own parameter RAM. 


You must initialize certain parameter RAM values before the serial management controller 
is enabled. Other values are initialized or written by the communication processor module. 
Once initialized, most parameter RAM values do not need to be accessed in your software 
since most of the activity is centered around the transmit and receive buffer descriptors and 
not the parameter RAM. However, if you access the parameter RAM, note the following 
restrictions. 


e The parameter RAM values that pertain to the SMC transmitter can only be written 
when the TEN bit in the SMCMR is zero. Or, after the STOP TRANSMIT command is 
issued, but before the RESTART TRANSMIT command is issued. 


¢ The parameter RAM values that pertain to the SMC receiver can only be written when: 


_1 The REN bit in the SMCMR is zero. 


1 The receiver is previously enabled after the ENTER HUNT MODE command is 
issued. 


1 The CLOSE RX BD command is issued and before the REN bit is set. 
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Table 16-36. SMC (UART and Transparent) Parameter RAM Memory Map 


ADDRESS NAME WIDTH DESCRIPTION | 
SMC Base + 00 RBASE | Half-Word RX BD Base Address . 
SMC Base + 02 TBASE Half-Word — TX BD Base Address | 


SMC Base + 04 RFCR RX Function Code 
SMC Base + 05 | TFCR TX Function Code 


Byte 
SMC Base + 08 RX Internal State 
SMC Base + 0C RX Internal Data Pointer 
SMC Base + 10 RX Buffer Descriptor Pointer 
SMC Base + 12 RX Internal Byte Count 
SMC Base + 14 RX Temp 
_ SMC Base + 18 TX Internal State 

SMC Base + 1C TX Internal Data Pointer 
SMC Base + 20 TX Buffer Descriptor Pointer 
SMC Base + 22 TX Internal Byte Count 
SMC Base + 24 TX Temp 


SMC Base + 28 | aa First Word of Protocol-Specific Area 


You are only responsible for initializing the items in bold. : 
SMC Base = (IMMR & OxFFFFO000) + 0x3E80 (SMC1) and 0x3F80 (SMC2). 





Last Word of Protocol-Specific Area 


Zz 
O 
aaa 
Mm 


e RBASE and TBASE—These entries are where the dual-port RAM starts the SMC 
receive and transmit buffer descriptors. They provide a great deal of flexibility in how 
buffer descriptors for a serial management controller are partitioned. By selecting 
RBASE and TBASE entries for the serial management controller and by setting the W 
bit in the last buffer descriptor in each buffer descriptor list, you can select how many 
buffer descriptors to allocate for the transmit and receive side of the serial management 
controller. However, you must initialize these entries before enabling the corresponding 
channel. Furthermore, you should not configure buffer descriptor tables of two enabled 
serial management controllers to overlap or erratic operation will occur. 


“Oo Note: RBASE and TBASE should contain a value that is divisible by eight. 
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e RFCR and TFCR—There are separate function code registers for the two SMC 
channels. One for receive data buffers (RFCR) and one for transmit data buffers 
(TFCR). The function code entry contains the value that you want to appear on the AT 
pins when the associated SDMA channel accesses memory. It also controls the 
byte-ordering convention that is used in the transfers. 


RFCR 


SMC1 AND SMC2 BASE + 0x04 


Bits O-2—Reserved 
These bits are reserved and should be set to 0. 


BO—Byte Ordering 


You should set these bits to select the required byte ordering of the data buffer. If this 
field is modified on-the-fly, it takes effect at the beginning of the next frame or the next 
buffer descriptor. 


00 = The DEC/Intel convention is used for byte ordering (swapped operation) and 
is also called little-endian byte ordering. The transmission order of bytes within 
a buffer word is reversed in comparison to the Motorola mode. This mode is 
supported only for 32-bit port size memory. | 

01 = PowerPC little-endian byte ordering. As data is transmitted onto the serial line 
from the data buffer, the least-significant byte of the buffer double-word 
contains data to be transmitted earlier than the most-significant byte of the 
same buffer double-word. 

1X = Motorola byte ordering (normal operation) is also called big-endian byte 
ordering. As data is transmitted onto the serial line from the data buffer, the 
most-significant byte of the buffer word contains data to be transmitted earlier 
than the least-significant byte of the same buffer word. 


AT—Address Type 


These bits contain the function code value used during the SDMA channel memory 
access. ATO is driven with a 1 to identify this SDMA channel access as a DMA type. 
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TFCR 





SMC1 AND SMC2 BASE + 0x05 


Bits O-2—Reserved 
These bits are reserved and should be set to 0. 


BO—Byte Ordering 


You should set these bits to select the required byte ordering of the data buffer. If this 
field is modified on-the-fly, it takes effect at the beginning of the next frame or the next 
buffer descriptor. 


00= The DEC/Intel convention is used for byte ordering (swapped operation) and 
is also called little-endian byte ordering. The transmission order of bytes within 
a buffer word is reversed in comparison to the Motorola mode. This mode Is 
supported only for 32-bit port size memory. 

-01= PowerPC little-endian byte ordering. As data is transmitted onto the serial line 
from the data buffer, the least-significant byte of the buffer double-word 
contains data to be transmitted earlier than the most-significant byte of the 

| same buffer double-word. 

1X = Motorola byte ordering (normal operation) is also called big-endian byte 
- ordering. As data is transmitted onto the serial line from the data buffer, the 
most-significant byte of the buffer word contains data to be transmitted earlier 
than the least-significant byte of the same buffer word. 


AT_—Address Type — 


These bits contain the function code value used during this SDMA channel memory 
access. ATO is driven with a 1 to identify this SDMA channel access as a DMA type. 
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e MRBLR—Each serial management controller has one maximum receive buffer length 
register to define the receive buffer length. The MRBLR defines the maximum number 
of bytes that the MPC823 writes to a receive buffer on the serial management controller 
before it moves on to the next buffer. The MPC823 can write fewer bytes to the buffer 
than MRBLR if a condition, such as an error or end-of-frame occurs, but it never writes | 
more bytes than the MRBLR value. It follows then, that buffers you supply should 
always be at least as long as the MRBLR. The transmit buffers for a serial management 
controller are not affected in any way by the value programmed into the MRBLR. 

Transmit buffers can be individually chosen to have varying lengths. The number of 
bytes to be transmitted is chosen by programming the DATA LENGTH field in the TX 
buffer descriptor. 


{ 
i 
{ 


edo 1S 4 
” 
i 


“Oo Note: The MRBLR is not intended to be changed dynamically while a serial 

| management controller is operating. However, if it is modified in a single bus 
cycle with one 16-bit move (not two 8-bit bus cycles back-to-back) then a 
dynamic change in receive buffer length can be successfully achieved. This 
occurs when the communication processor module moves control to the next RX 
buffer descriptor in the table. Thus, a change to MRBLR does not have an 
immediate effect. To guarantee the exact RX buffer descriptor on which the 
change occurs, you should only change the MRBLR while the SMC receiver is 
disabled. The value of MRBLR should be greater than zero and should be even 
if the character length of the data is greater than 8 bits. 


e RBPTR—The receiver buffer descriptor pointer for each SMC channel points to the 
next buffer descriptor the receiver transfers data to when it is in idle state or to the 
current buffer descriptor during frame processing. After a reset or when the end of the 
buffer descriptor table is reached, the communication processor module initializes this 
pointer to the value programmed in the RBASE entry. Although you will not usually need 
to write the RBPTR in most applications, you can modify it when the receiver is disabled 
or when you are sure no receive buffer is currently being used. 


e TBPTR—The transmitter buffer descriptor pointer for each SMC channel points to the 
next buffer descriptor the transmitter transfers data from when it is in idle state or to the 
current buffer descriptor during frame transmission. After a reset or when the end of the 
buffer descriptor table is reached, the communication processor module initializes this 
pointer to the value programmed in the TBASE register. Although you will not usually 
need to write TBPTR in most applications, you can modify it when the receiver is 
disabled or when you are sure no receive buffer is currently being used. 
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e Other General Parameters—You do not need to access these parameters during 

~ normal operation. They are only listed because they provide helpful information for 
experienced users and for debugging purposes. Additional parameters are listed in 
Table 16-33. The RX and TX internal data pointers are updated by the SDMA channels 
to show the next address in the buffer to be accessed. TCNT is a down-count value that 
is initialized with the TX buffer descriptors’ DATA LENGTH field and decremented with 
every byte read by the SDMA channels. RCNT is a down-count value that is initialized 
with the MRBLR value and decremented with every byte written by the SDMA channels. 
RSTATE, TSTATE, RTEMP, TTEMP, and the reserved areas are only used by the 
RISC microcontroller. 


Note: To extract data from a aes full receive buffer, use the CLOSE RX BD 
command. 


16.11.5 Disabling the SMCs On-the-Fly 


lf you do not need a serial management controller, it can be disabled and reenabled later. 
In which case, you must follow a particular sequence of steps to ensure that the buffers are 
properly closed and that new data is transferred to or from a new buffer. Such a sequence 
is required if the parameters you want to change are not dynamic. If the register or bit 
description states that dynamic or on-the-fly changes are allowed, you do not have to follow 
the sequences and the register or bit can can be changed immediately. 


= NOE: The serial management controller does not have to be fully disabled for you to 
: | modify the parameter RAM. Refer to the parameter RAM description for details 
on when parameter RAM values can be modified. If you want to disable the 
SCC2, USB, SMCs, SPI, and I@C, use the CPM command register to reset the 

communication processor a with a single command. 
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16.11.5.1 DISABLING THE ENTIRE SMC TRANSMITTER. Follow these steps to fully 
enable or disable the SMC transmitter: 


1. 


Issue the STOP TRANSMIT command. This command is recommended when a serial 
management controller is transmitting data since it stops transmission smoothly. Ifa 
serial management controller is not transmitting, then this command is not required. 

Furthermore, if you overwrite the TBPTR or the INIT TX PARAMETERS command is 
executed, this command is not required. 


Clear the TEN bit in the SMCMR. This disables the SMC transmitter and puts it in a 
reset state. 


Make modifications. You can make modifications to the SMC transmit parameters, 
including the parameter RAM. If you prefer to switch protocols or restore the SMC 
transmit parameters to their initial state, issue the INIT TX PARAMETERS command. 


Issue the RESTART TRANSMIT command. You must do this if you did not issue the 
INIT TX PARAMETERS command in step 3. 


. Set the TEN bit in the SMCMR. Transmission now begins using the TX buffer 


descriptor that the TBPTR value pointed to as soon as the R bit is set in the TX buffer 
descriptor. | 


16.11.5.2 DISABLING PART OF THE SMC TRANSMITTER. Follow this shorter 
sequence if you prefer to reinitialize the transmit parameters to the state they had after reset. 


1. 
2. 
is 


Clear the TEN bit in the SMCMR. 
Issue the INIT TX PARAMETERS command and make any additional modifications. 
Set the TEN bit in the SMCMR. 


16.11.5.3 DISABLING THE ENTIRE SMC RECEIVER. Follow these steps to fully enable 
or disable the receiver: 


1. 


Clear the REN bit in the SMCMR. Reception is aborted immediately, which disables 
the SMC receiver and puts it in a reset state. 


. Make modifications to the SMC receive parameters, including the parameter RAM. If 


you prefer to switch protocols or restore the SMC receive parameters to their initial 
state, issue the INIT RX PARAMETERS command. 


. Issue the CLOSE RX BD command. You must do this if you did not issue the INIT RX 


PARAMETERS command in step 2. 


. Set the REN bit in the SMCMR. Reception begins immediately using the RX buffer 


descriptor that the RBPTR pointed to if the E bit is set in the RX buffer descriptor. 
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16.11.5.4 DISABLING PART OF THE SMC RECEIVER. Follow this shorter sequence to 
reinitialize the receive parameters to the state they had after reset. 


1. Clear the REN bit in the SMCMR. 
2. INIT RX PARAMETERS command and make any additional modifications. 
3. Set the REN bit in the SMCMR. 


16.11.5.5 SWITCHING PROTOCOLS. To switch the protocol that a serial management 
controller is executing without resetting the board or affecting any other serial management 
controller, use one commana and follow these steps: 


{. Clear the TEN and REN bits in the SMCMR. 


2. Issue the INIT TX AND RX PARAMS command. It initializes the transmit and receive 
parameters. Make any additional modifications in the SMCMR 


3. Set the TEN and REN bits in the SMCMR. The serial management controller is now 
enabled with the new protocol. 


Tip: | You can save power by clearing the TEN and REN bits of a serial management 
controller. 





16.11.6 The SMC in UART Mode 


Compared to the SCC2 in UART mode, the serial management controllers are designed to 
support simple debug/monitor ports instead of full-featured UART controllers. The following 
is a list of the features that the SMC in UART mode does not support. 

¢ RTS, CTS, and CD pins | | | 

e Receive and transmit sections clocked at different rates 


Fractional stop bits 


Built-in multidrop modes 


Freeze mode for implementing flow control 


Isochronous operation (1x clock) 
_ © Interrupts on special control character reception 
e Ability to transmit data on demand using the TODR 
However, the SMC in UART mode dees provide one feature that the SCC? j in UART mode 
does not. It allows a data length of up to 14 bits, whereas the serial communication controller 


only goes up to 8 bits. The SMC in UART mode is also referred to as the SMC UART 
controller. 
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Figure 16-115. SMC UART Frame Format 


16.11.6.1 FEATURES. The following list summarizes the main features of the SMC in 
UART mode: 


e Flexible message-oriented data structure 

e Programmable data length (5—14 bits) 

° Programmable 1 or 2 stop bits _ | 
° Even/odd/no parity generation and checking | 
e Frame error, break, and idle detection 

e Transmit preamble and break sequences 

¢ Received break character length indication 

¢ Continuous receive and transmit modes 


16.11.6.2 SMC UART CHANNEL TRANSMISSION PROCESS. The UART transmitter is 
designed to work with almost no intervention from the core. When the core enables the SMC 
transmitter, it starts transmitting idles. The SMC UART controller immediately polls the first 
buffer descriptor in the transmit-channel buffer descriptor ring and once every character time 
after that, depending on the character length. When there is a message to transmit, the SMC 
UART controller fetches the data from memory and starts transmitting the message. 


When buffer descriptor data is completely written to the transmit FIFO, the SMC UART | 
controller writes the message status bits into the buffer descriptor and clears the R bit. An 
interrupt is issued if the | bit in the buffer descriptor is set. If the next TX buffer descriptor is 
ready, the data from its data buffer is appended to the previous data and transmitted out on 
the transmit pin, without any gaps between the buffers. If the next TX buffer descriptor is not 
ready, the SMC UART controller starts transmitting idles and waits for the next TX buffer 
descriptor to be ready. 
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By appropriately setting the | bit in each buffer descriptor, interrupts can be generated after 
the transmission of each buffer, a specific buffer, or each block. The SMC UART controller 
then proceeds to the next buffer descriptor in the table. If the CM bit is set in the TX buffer 
descriptor, the R bit is not cleared, allowing the associated data buffer to be automatically 
retransmitted next time the communication processor module accesses this data buffer. For 
instance, if a single TX buffer descriptor is initialized with the CM and W bits set, the data 

buffer is continuously transmitted until you clear the R bit of the buffer descriptor. 


16.11.6.3 SMC UART CHANNEL RECEPTION PROCESS. When the core enables the 
SMC receiver in UART mode, it enters hunt mode and waits for the first character to arrive. 
Once the first character arrives, the communication processor module checks the first RX 
buffer descriptor to see if it is empty and then starts storing characters in the associated data 
buffer. | | 


When the data buffer is filled or the MAX_IDL timer expires if it is enabled, the SMC UART 
controller clears the E bit in the buffer descriptor and generates an interrupt if the | bit in the 
buffer descriptor is set. If the incoming data exceeds the length of the data buffer, the SMC 
UART controller fetches the next buffer descriptor in the table and, if it is empty, continues 
transferring data to this buffer descriptor associated data buffer. If the CM bit is set in the RX 
buffer descriptor, the E bit is not cleared, which allows the associated data buffer to be 
automatically overwritten next time the communication processor module accesses this 
data buffer. 


16.11.6.4 SMC UART PARAMETER RAM MEMORY MAP. When configured to operate 
in UART mode, the SMC UART controller overlays the structure used in Table 16-36 with 
the parameters described in Table 16-37. 


Table 16-37. SMC UART Parameter RAM Memory Map 


[wae [wom | —_oesowrnon 






ADDRESS 


- SMC Base + 28 












SMC Base + 2E BRKEC - Half-word Receive Break Condition Counter 
SMC Base +30 BRKCR Half-word Break Count Register (Transmit) 
SMC Base +32 R_MASK Half-word | Temporary Bit Mask 


NOTE: You are only responsible for initializing the items in bold. 
SMC Base = (IMMR & OxFFFFO000) + 0x3E80 (SMC1) and 0x3F80 (SMC2). 
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e MAX_!DL—Once a character of data is received on the line, the SMC UART controller 
starts counting any idle characters received. If a MAX_IDL number of idle characters is 
received before the next data character, an idle timeout occurs and the buffer closes. 
This, in turn, produces an interrupt request to the core to receive the data from the 
buffer. MAX_IDL provides a convenient way to demarcate frames in SMC UART mode. 
But if you do not want to use MAX_IDL, you should program MAX_IDL to 0x0000 and 
the buffer will never close, regardless of the number of idle characters received. The 
number of bits in an idle character is calculated as follows—1 + character data length 
(5 to 14) +1 (if parity bit is used) + number of stop bits (1 or 2). For example, for a 
character data length of 8, no parity, and 1 stop bit, the idle character length is 10 bits. 


¢ IDLC—This value is used by the RISC microcontroller to store the current idle counter 
value in the MAX_IDL timeout process. IDLC | is a down-counter that you do not need to 
initialize or access. 


¢ BRKLN—This value is used to store the length of the last break character received and 
is the bit length of that character. For example, if the receive pin is low for 257 bit times, 
BRKLN shows the value 0x0101 and it is accurate to within one character unit of bits. 
For 8 data bits, no parity, 1 stop bit, and 1 start bit, BRKLN Is accurate to within 10 bits. 


e BRKEC—This counter counts the number of break conditions that occur on the line. 
One break condition can last for hundreds of bit times, yet this counter is only 
incremented once during that period. 


e BRKCR—This value indicates when the SMC UART controller sends a break character 
sequence aftera STOP TRANSMIT command is issued. The number of break 
characters sent by the SMC UART controller is determined by the value in BRKCR. For 
8 data bits, no parity, 1 stop bit, and 1 start bit, each break character is 10 bits long and 
consists of all zeros. 


e R_MASK—This value is a temporary bit mask used internally by the SMC UART 
controller. 


16.11.6.5 PROGRAMMING THE SMC UART CONTROLLER. The SMC UART 
controllers data structure supports multibuffer operation and allows you to transmit break 
and preamble sequences. Overrun, parity, and framing errors are reported via the buffer 
descriptors. In its simplest form, the SMC UART controller functions in a character-oriented 
environment. Each character is transmitted with the stop bits and parity that you configure. 
Characters are received into separate 1-byte buffers. A maskable interrupt can be | 
generated when each buffer is filled. 7 


Many applications may want to take advantage of the message-oriented capabilities that the 
SMC UART controller supports through linked buffers for reception or transmission. You can 
handle data in a message-oriented environment and work on entire messages rather than 
on acharacter-by-character basis. A message can span several linked buffers and each one 
can be transmitted and received as a linked list of buffers without any intervention from the 
core, which makes it easy to program and saves processor overhead. In a message- 
oriented environment, the idle sequence is used as the message delimiter. The transmitter 
can generate an idle sequence before starting a new message and the receiver can close a 
buffer when an idle sequence is found. 
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16.11.6.6 SMC UART COMMANDS. You can program the CPM command register 
(CPCR) with the following commands to transmit data. _ 


e STOP TRANSMIT—This command disables the transmission of characters on the 
transmit channel. If the SMC UART controller receives this command while transmitting 
a message, it stops transmitting. The SMC UART controller finishes transmitting any 
data that has already been transferred to its FIFO and shift register and then stops 
transmitting data. The TBPTR is not advanced when this command is issued. The SMC 
UART controller transmits a programmable number of break sequences and then 
transmits idles. The number of break sequences, which can be zero, should be written 
to the BRKCR entry before this command is issued to the SMC UART controller. 


RESTART TRANSMIT—This command enables characters to be transmitted on the 
transmit channel. The SMC UART controller expects it after disabling the channel in its 
SMCMR and after issuing the STOP TRANSMIT command. The SMC UART controller 
resumes transmission from the current TBPTRi in the channel’s TX buffer descriptor 
table. | 

INIT TX PARAMETERS—This command initializes all the transmit parameters in this 
serial channel's parameter RAM to their reset state and should only be issued when the 
transmitter is disabled. The INIT TX AND RX PARAMS command can also be used to 
reset the transmit and receive parameters. 


You.can program the CPCR with the following commands to receive data. 


¢ ENTER HUNT MODE—You should not use this command for an SMC UART channel. 
You should use the CLOSE RX BD command instead. 


CLOSE RX BD—This command is used to force a ae management controller to 
close the current receive buffer descriptor if it is currently being used and to use the next 
buffer descriptor in the list for any subsequently received data. If a serial management 
controller is not in the process of receiving data, no action is taken by this command. 


INIT RX PARAMETERS—This command Initializes all the receive parameters in this 
serial channel parameter RAM to their reset state. This command should only be issued 

-~when the receiver is disabled. The INIT TX AND RX PARAMS command can also be 
used to reset the receive and transmit parameters. 


16.11.6.7 SENDING A BREAK. A break is an all-zeros character without stop bits and it is 
sent by issuing the STOP TRANSMIT command. The SMC UART controller finishes _ 
transmitting any outstanding data and then sends a character with consecutive zeros. The 
number of zero bits in this character is the sum of the character length, plus the number of 
start, parity, and stop bits. The SMC UART controller transmits a programmable number of 
break characters according to the BRKCR entry and then reverts to idle or sends data if the 
RESTART TRANSMIT command was issued before completion. When the break is 
completed, the transmitter sends at least one idle character before transmitting any data to 
guarantee recognition of a valid start bit. 
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16.11.6.8 SENDING A PREAMBLE. A preamble sequence provides a convenient way for 
you to ensure that the line is idle before you start anew message. The preamble sequence 
is constructed of consecutive ones that are one character long. If the preamble bit in a buffer 
descriptor is set, a serial management controller sends a preamble sequence before | 
transmitting that data buffer. For 8 data bits, no parity, 1 stop bit, and 1 start bit, a preamble 
of 10 ones would be sent before the first character in the buffer. If no preamble sequence is 
sent, data from two ready transmit buffers can be transmitted without causing a delay on the 
transmit pin between the two transmit buffers. 


16.11.6.9 SMC UART CONTROLLER ERRORS. The SMC UART controller reports: — 
character reception error conditions via the channel buffer descriptors and the SMC UART 
event register. The SMC UART controller has no transmission errors, which means you 
cannot stop the transmission of characters in SMC UART mode. 


¢ Overrun Error—The SMC UART controller maintains a two-character length FIFO for 
receiving data. The data is moved to the buffer after the first character is received into 
the FIFO and if a receiver FIFO overrun occurs, the channel writes the received 
character into the internal FIFO. Then the channel writes the received character to the 
buffer, closes it, sets the OV bit in the buffer descriptor, and generates the RX interrupt 
if itis enabled. Reception then continues as normal. 


_ Note: The SMC UART controller may occasionally gel a an overrun error when the line 
is idle, in which case you should ignore the error. 


e Parity Error—When this error occurs, the channel writes the received character to the 
buffer, closes it, sets the PR bit in the buffer descriptor, and generates the RX interrupt 
if it is enabled. Reception then continues as normal. 


e Idle Sequence Receive Error—An idle is found when one character consisting of all 
ones is received. Once an idle is received, the channel counts the number of 
consecutive idle characters. If the count reaches the MAX_IDL value, the buffer is 
closed, and an RX interrupt is generated. If no receive buffer is open, this event does 
not generate an interrupt or any status information. The idle counter is reset every time 
a character is received. 


e Framing Error—The SMC UART controller receives this error when it receives a 
character with no stop bit. When it occurs, the channel writes the received character to 
the buffer, closes the buffer, sets the FR bit in the buffer descriptor, and generates the 
RX interrupt if it is enabled. When this error occurs, parity is not checked for the 
character. 


e Break Sequence Error—This error occurs when the SMC UART receiver receives an 
all-zero character with a framing error. When it occurs, the channel increments the 
BRKEC entry and generates a maskable BRK interrupt in the SMCE—UART register. 
The channel also measures the length of the break sequence and stores this value in 
the BRKLN counter. If the channel was in the middle of buffer processing when the 
break was received, the buffer is closed with the BR bit in the RX buffer descriptor set 
and the RX interrupt is generated if it is enabled. 
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16.11.6.10 SMC UART MODE REGISTER. When the SMC is in UART mode, the 16-bit, 
memory-mapped, read/write SMC mode register is referred to as the SMC UART mode | 

register (SMCMR-UART). The functionality of bits 8-15 is common to each SMC protocol, 
but bits 0-7 vary according to the protocol selected by the SM field. This register | is cleared 


by reset. 


SMCMR-UART 





(IMMR & OxFFFF0000) + 0xA82 (SMC1), 0xA92 (SMC2) 


Bits 0 and 8—-9—Reserved 
These bits are reserved and should be set to 0. 


CLEN—Character Length 


This field should be programmed with the total number of bits in the character minus one. 
The total number of bits in the character is calculated as the sum of 1 (start bit always 
present) + number of data bits (5 to 14) + number of parity bits (0 or 1) + number of stop bits 
(1 or 2). For example, for 8 data bits, no parity, and 1 stop bit, the total number of bits in the 
character is 1 + 8+0+1=10. So, CLEN should be programmed to 9. 


‘The number of data bits in the character ranges from 5 to 14 bits. If the data bit length is less 


than 8 bits, the most-significant bits of each byte in memory are not used on transmission 
and are written with zeros on reception. On the other hand, if the data bit length is more than 
8 bits, the most-significant bits of each 16-bit word in memory are not used on transmit and 
are written with zeros on receive. 


Note: The total number of bits in the character must never exceed 16. Thus, if you 
choose a 14-bit data length, you should set SL to one stop bit and not enable 
parity. If you choose a 13-bit data length and parity is enabled, you should set 
SL to one stop bit. You should not write the values 0-3 to CLEN or else erratic 
behavior will occur. 





SL—Stop Length 


O= One stop bit. 
1 = Two stop bits. 


PEN—Parity Enable 


O = No parity. 
1 = Parity is enabled for the transmitter and receiver as determined by the PM bit. 
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PM—Parity Mode 
O= Odd parity. | se 
1 = Even parity. | | cs 


SM—SMC Mode 


00 = GCI or SCIT support. 

O1 = Reserved. 

10 = UART (must be selected for SMC UART operation). 
11 = Totally Transparent operation. 


DM—Diagnostic Mode 


0O = Normal operation. 

01 = Local loopback mode. 
10 = Echo mode. 

11 = Reserved. 


TEN—SMC Transmit Enable 


O= SMC transmitter disabled. 
1 = SMC transmitter enabled. 


REN—SMC Receive Enable 


O= SMC receiver disabled. 
1 = SMC receiver enabled. 


16.11.6.11 SMC UART RECEIVE BUFFER DESCRIPTOR. Using the buffer descriptors, 
the communication processor module reports information about the received data ona 
per-buffer basis. It then closes the current buffer, generates a maskable interrupt, and starts 
receiving data into the next buffer after one of the following events occurs: 


e An error is received while a message is being processed. 


e A full receive (RX) buffer is detected. 
°e A programmable number of consecutive idle characters are received. 


“oO Note: The communication processor module sets all the status bits in this buffer 

descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 
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re [ees] w | 1 [pesca eu | 0 [pesenven[ ap | en |e [es] ov [RES 


RX DATA BUFFER POINTER 





NOTE: You are only responsible for initializing the items in bold. 


E—Empty 
0 = The data buffer associated with this RX buffer descriptor is filled with received data 


or data reception is aborted due to an error condition. The core Is free to examine 
or write to any fields of this RX buffer descriptor. The communication processor 
module does not use this buffer descriptor as long as the E bit is zero. 

The data buffer associated with this buffer descriptor is empty or reception is 
currently in progress. This RX buffer descriptor and its associated receive buffer 
are owned by the communication processor module. Once the E bit is set, the core 
should not write any fields of this RX buffer descriptor. 


Bits 1, 4-5, 8-9, 13, and 15—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Buffer Descriptor in Table) 
0 = This is not the last buffer descriptor in the RX buffer descriptor table. 


Le 


This is the last buffer descriptor in the RX buffer descriptor table. After this buffer 
is used, the communication processor module receives incoming data into the first 
buffer descriptor that RBASE points to in the table. The number of RX buffer 
descriptors in this table is programmable and determined ony by the W bit and 
overall space constraints of the dual-port RAM. 


I—Interrupt 
O = No interrupt is generated after this buffer is filled. 


1= 


The RX bit in the event register is set when this buffer is completely filled by the 
communication processor module, indicating the need for the core to process the 
buffer. The RX bit can cause an interrupt if it is enabled. 


CM—Continuous Mode 
O = Normal operation. 


ie— 


16-390 


The E bit is not cleared by the communication processor module after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
overwritten next time the communication processor module accesses this buffer 
descriptor. However, the E bit is cleared if an error occurs during reception, 
regardless of how the CM bit is set. 
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|ID—Buffer Closed on Reception of Idles 


This bit indicates that the buffer has closed because a programmable number of consecutive 
idle sequences have been received. The communication processor module writes this bit 
after the received data is in the associated data buffer. 


BR—Buffer Closed on Reception of Break 


This bit indicates that the buffer has closed because a break sequence has been received. 
The communication processor module writes this bit after the received data is in the 
associated data buffer. 


O = No break sequence Is received. 
1 = Buffer closed upon reception of a break sequence. 


FR—Framing Error 


This bit indicates that a character with a framing error has been received and located in the 
last byte of this buffer. A framing error is a character without a stop bit. A new receive buffer 
is used to receive additional data. The communication processor module writes this bit after 
the received data is in the associated data buffer. 


PR—Parity Error 

This bit indicates that a character with a parity error has been received and located in the 
last byte of this buffer. A new receive buffer is used to receive additional data. The 
communication processor module writes this bit after the received data is in the associated 
data buffer. 


OV—Overrun 


This bit indicates that a receiver overrun has occurred during message reception. The 
communication processor module writes this bit after the received data is in the associated 
data buffer. 


DATA LENGTH 


This field represents the number of octets the communication processor module writes into 
this buffer descriptor data buffer. After the data is received in the associated data buffer, the 
communication processor module writes this field once the buffer descriptor closes. 


Note: The actual amount of memory allocated for this buffer should be greater than or 
equal to the MRBLR entry. 


RX DATA BUFFER POINTER 


This field always points to the first location of the associated data buffer and must be even. 
The buffer can reside in internal or external memory. The communication processor module 
writes this bit after the received data is in the associated data buffer. 
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Figure 16-116 illustrates an example of the RX buffer descriptor process. It shows the 
resulting state of the RX buffer descriptors after they receive 10 characters, an idle period, 
and five characters (one with a framing error). The example assumes that MRBLR = 8 in the 
SMC parameter RAM. 


MRBLR = 8 BYTES FOR THIS SMC 












RECEIVE BD 0 
BUFFER 
E ID UFFE 
STATUS 
LENGTH BUFFER 8 BYTES 
FULL 
POINTER 32-BIT BUFFER POINTER 
RECEIVE BD 1 
E ID BUFFER 
IDLE TIMEOUT 
POINTER 32-BIT BUFFER POINTER ~ OCCURRED | 
RECEIVE BD 2 
E ID FR BUFFER 


STATUS 


LENGTH 


BYTE 4HAS 8 BYTES © 
FRAMING ERROR wae 
POINTER 





1 STORED UNLESS IDLE 
COUNT EXPIRES 


WITH THIS (MAX_IDL) 
BUFFER 


AD 
BYTES WILL BE | 8 BYTES 





10 CHARS . 5 CHARS 
<—___§_—___ > 








LONG IDLE PERIOD 


CHARACTERS | | 
RECEIVED BY UART : PRESENT 
FOURTH CHARACTER = TIME 
TIME ——> HAS FRAMING ERROR! : 


Figure 16-116. SMC UART Receive Buffer Descriptor Example 
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16.11.6.12 SMC UART TRANSMIT BUFFER DESCRIPTOR. Data is sent to the 
communication processor module for transmission on an SMC channel by arranging it in 
buffers referenced by the channel’s transmit (TX) buffer descriptor ring. Using the buffer 
descriptors, the communication processor module confirms transmission or indicates error 
conditions so that the processor knows the buffers have been serviced. 













Pa fres| w [1 fresemven| cu] p | RESERVED 


TX DATA BUFFER POINTER 


NOTE: You are only responsible for initializing the items in bold. 


descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 


Py 4 Note: The communication processor module sets all the status bits in this buffer 


R—Ready | 

0 = The data buffer associated with this buffer descriptor is not ready for transmission, 
but you are free to manipulate this buffer descriptor or its associated data buffer. 
The communication processor module clears this bit after the buffer has been 
transmitted or an error condition is encountered. | 

1 = The data buffer, which you prepare for transmission, is not transmitted yet or is 
currently being transmitted. You cannot write any fields of this buffer descriptor 
once this bit is set. | 


Bits 1, 4-5, and 8-15—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Buffer Descriptor in Table) 


0 = This is not the last buffer descriptor in the TX buffer descriptor table. 

1 = This is the last buffer descriptor in the TX buffer descriptor table. After this buffer is 
used, the communication processor module receives incoming data into the first 
buffer descriptor that TBASE points to in the table. The number of TX buffer 
descriptors in this table is programmable and determined only by the W bit and 
overall space constraints of the dual-port RAM. 
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I—Interrupt 


0 = No interrupt is generated after this buffer | is serviced. 
1 = The TX bit in the SMCE—-UART register is set when this buffer is serviced. 
Transmission can cause an interrupt if it is enabled. 





CM—Continuous Mode 


NO —~ Aianrmal annarvatinn 

Vom IWULITIC UVOIAUUVUIT. 

1 = The R bit is not cleared by the communication processor module after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
retransmitted next time the communication processor module accesses this buffer 
descriptor. 

P—Preamble 


0 = No preamble sequence is sent. 

1 = The SMC UART controller sends one all-ones character before it Sendé the data 
so that the other end detects an idle line before the data is received. If this bit is set 
and the data length of this buffer descriptor is zero, only a preamble is sent. 


DATA LENGTH 


This field represents the number of octets that the communication processor module should 
transmit from this buffer descriptor data buffer. However, it is never modified by the 
communication processor module. Normally, this value should be greater than zero, but it 
can be equal to zero with the P bit set if only a preamble is sent. 


If the number of data bits in the SMC UART character is greater than 8, then the data length 
should be even. For example, to transmit three UART characters of 8-bit data, 1 start, and 
1 stop, the DATA LENGTH field should be initialized to 3. However, to transmit three SMC 
UART characters of 9-bit data, 1 start, and 1 stop, the DATA LENGTH field should be 
initialized to 6, since the three 9-bit data fields occupy three half-words in memory (the 9 
least-significant bits of each half-word). 


TX DATA BUFFER POINTER 


This field always points to the first location of the associated data buffer. It can be even or 
odd, unless the number of actual data bits in the SMC UART character is greater than 8 bits, 
in which this field is even. For instance, the pointer to 8-bit data, 1 start, and 1 stop | 
characters can be even or odd, but the pointer to 9-bit data, 1 start, and 1 stop characters 
must be even. The buffer can reside in internal or external memory. 
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16.11.6.13 SMC UART EVENT REGISTER. When the SMC is in UART mode, the 8-bit 
memory-mapped SMC event register is referred to as the SMC UART event (SMCE—UART) 
register. It is used to generate interrupts and report events recognized by the SMC UART 
channel. When an event is recognized, the SMC UART controller sets the corresponding bit 
in this register. 


A bit is cleared by writing a 1 (writing a zero has no effect) and more than one bit can be 
cleared at a time. All unmasked bits must be cleared before the communication processor 
module clears the internal interrupt request. This register is cleared by reset and can be read 
at any time. An example of the timing of various events in the SMCE—UART register is 
illustrated in Figure 16-117. | 


SMCE —UART 
















BRKE RESERVED 


po fe fofe]efele fo 


(IMMR & OxFFFFO000) + 0xA86 (SMC1), 0xA96 (SMC2) 


Bit 0, 2, and 4—Reserved 
These bits are reserved and should be set to 0. 


BRKE—Break End 


This bit indicates that an end of break sequence has been detected. It occurs no sooner than 
after one idle bit is received after a break sequence. 


BRK—Break Character Received 


This bit indicates that a break character has been received. If a very long break sequence 
occurs, this interrupt only occurs once after the first all-zeros character is received. 


BSY—Busy Condition 


This bit indicates that a character has been received and discarded due to a lack of buffers. 
It is be set no sooner than the middle of the last stop bit of the first receive character for 
which there is no available buffer. Reception continues when an empty buffer is provided. 


TX—TX Buffer 


This bit indicates that a buffer has been transmitted over the SMC UART channel. It is set 
once the transmit data of the last character in the buffer is written to the transmit FIFO. You 
must wait two character times to be sure that the data is completely sent over the transmit 


pin. 


MOTOROLA MPC823 USER’S MANUAL 16-395 


SHC 


tu 
—_! 
ra 
Xe) 
4 
_— 
<cc 
O°. 
z= 
> 
=O 
ro) 
Ox 
on. 





~ Communication Processor Module 


RX—Receive Buffer 
eg) This bit indicates that a buffer has been received and its associated RX buffer descriptor is 


= 


{NES 


now closed. It is set no sooner than the middle of the last stop bit of the last character that 
is written to the receive buffer. 


(oO, 


CHARACTERS 


RECEIVED BY SMC YABt a 40 CHARACTERS 
TIME —> 2 


LINE IDLE 





RXD LINE IDLE 


SMC UART SMCE 
EVENTS 


RX RX BRK BRKE 
NOTES: | 


1. The first RX event assumes receive buffers are six bytes each. 
_ 2. The second RX event position is programmable based on the max_IDL value. 
3. The BRK event occurs after the first break character is received. 


CHARACTERS 


TRANSMITTED BY SMC UART gut CHARACTERS ; 
TXD LINE IDLE LINE IDLE 
SMC UART SMCE 
EVENTS 





TX 


NOTE: The TX event assumes all seven characters were put into a single buffer, and the TX event occurred when the seventh 
character was written to the SMC transmit FIFO. 


Figure 16-117. SMC UART Interrupt Example 
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16.11.6.14 SMC UART MASK REGISTER. When the SMC is in UART mode, the 8-bit 
read/write SMC mask register is referred to as the SMC UART mask (SMCM-—UART) 
register. It has the same bit format as the SMCE-UART register. If a bit in this register is a 
1, the corresponding interrupt in the SMCE-UART register is enabled. If the bit is zero, the 
corresponding interrupt in the SMCE—UART register is masked. 


SMCM —UART 









resenveo| ere [esenven| om [resenven| asy | me | 
Po fe fe fe] e fe] fo 
Taw [aw [aw [aw [aw [aw [aw 


(IMMR & OxFFFF0000) + 0xA8A (SMC1), 0xA94 (SMC2) 





16.11.6.15 SMC UART CONTROLLER PROGRAMMING EXAMPLE. The following is an 
initialization Sequence for 9,600 baud, 8 data bits, no parity, and 1 stop bit operation of an 
SMC UART controller assuming a 25MHz system frequency. BRG1 and SMC1 are used. 


1. Configure the port B pins to enable SMTXD1 and SMRXD1. Write PBPAR bits 25 and 
24 with ones and then PBDIR and PBODR bits 25 and 24 with zeros. 


2. Configure the BRG1. Write 0x010144 to BRGC1. The DIV16 bit is not used and the 
divider is 162 (decimal). The resulting BRG1 clock is 16x the preferred bit rate of the 
SMC UART controller. 


3. Connect the BRG1 clock to SMC1 using the serial interface. Write the SMC1 bit in 
SIMODE with a 0 and the SMC1CS field in SIMODE register with 0x000. 


4. Write RBASE and TBASE in the SMC parameter RAM to point to the RX buffer 
descriptor and TX buffer descriptor in the dual-port RAM. Assuming one RX buffer 
descriptor at the beginning of dual-port RAM and one TX buffer descriptor following 
that RX buffer descriptor, write RBASE with 0x2000 and TBASE with 0x2008. 


5. Program the CPCR to execute the INIT RX AND TX PARAMS command. Write 
0x0091 to the CPCR. 


6. Write 0x0001 to the SDCR to initialize the SDMA configuration register. 
7. Write 0x18 to the RFCR and TFCR for normal operation. 


8. Write MRBLR with the maximum number of bytes per receive buffer. Asume 16 bytes, 
so MRBLR = 0x0010. 


9. Write MAX_IDL with 0x0000 in the SMC UART parameter RAM to disable the 
MAX_IDL functionality for this example. 


10. Clear BRKLN and BRKEC in the SMC UART parameter RAM for the clarity. 


11.Set BRKCR to 0x0001, so that ifa STOP TRANSMIT command is issued, one break 
character is sent. 
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12. Initialize the RX buffer descriptor. Assume the RX data buffer is at 0x00001000 in main 
oa, memory. Write OxBO00 to RX_BD_Status, 0x0000 to RX_BD_Length (not heguired) 
“i \ and 0x00001000 to RX_BD_Pointer. 


eed Hi 13. Initialize the TX buffer descriptor. Assume the TX data buffer is at Ox00002000 in main 
memory and contains five 8-bit characters. Then write OxBOOO to TX_BD_Status, 
0x0005 to TX_BD_Length, and 0x00002000 to TX_BD_Pointer. 


=) 


15.Write 0x17 to the SMCM-UART cena to enable all possible s serial management 
controller interrupts. 


16.Write 0x00000010 to the CIMR so SMC1 can generate a system interrupt. The CICR 
should also be initialized. 

17.Write 0x4820 to SMCMR to configure normal operation (not loopback), 8-bit 
characters, no parity, 1 stop bit. Notice that the transmitter and receiver are not 
enabled yet. 


18.Write 0x4823 to SMCMR to enable the SMC transmitter and receiver. This additional 
write ensures that the TEN and REN bits are enabled last. 


Note: After 5 bytes are transmitted, the TX buffer descriptor is closed. The receive 
buffer is closed after 16 bytes are received. Any data received after 16 bytes 
causes a busy (out-of-buffers) condition since only one RX buffer cesenpior is 
prepared. 





16.11.6.16 HANDLING INTERRUPTS IN THE SMC UART CONTROLLER. Follow these 
steps to handle an interrupt in a serial management controller: | 


1. Once an interrupt occurs, read the SMCE—UART register to find out what caused it. 
To clear the SMCE bits, write ones to them. 


2. Process the TX buffer descriptor to reuse it if the TX bit is set in the SMCE-—-UART 
register. Extract data from the RX buffer descriptor if the RX bit is set in the . 
SMCE-UART. To transmit another buffer, simply set the R bit in the TX buffer 
descriptor. 


3. Clear the SMCx bit in the CISR. 
4. Execute the rfi instruction. 


DO 
ok 
O= 
nS 
n= 
roXe) 
2 
=o 
o= 
Cc 

rm 

m 





16-398 ~MPC823 USER’S MANUAL ~MOTOROLA 


Communication Processor Module 


16.11.7 The SMC in Transparent Mode 


The SMC in Transparent mode is also referred to as the SMC Transparent controller. The 
following is a list of the features that the SMC Transparent controller does not support: 


e Independent transmit and receive clocks, unless connected to a TDM channel of the 
serial interface 


e CRC generation and checking 

e Full RTS, CTS, and CD pins. Instead, there is a SMSYN pin for each SMC. 
e Ability to transmit data on demand using the TODR 

e Receiver/transmitter in transparent mode while executing another protocol 
e 4-, 8-, or 16-bit Sync recognition 

e Internal DPLL support 


The SMC in Transparent mode provides one feature that the SCC2 in Transparent mode did 
not. The serial management controllers allow a data character length option of 4 to 16 bits, 
whereas the SCC2 provides 8 or 32 bits, depending on how the RFW bit is set in the 
GSMR_H, which is described in Section 16.9.2 The General SCC2 Mode Registers. 


16.11.7.1 FEATURES. The following list summarizes the features of the SMC in 
Transparent mode: 


e Flexible data buffers 
e Connects to a TDM bus using the time-slot assigner in the serial interface 


e Transmits and receives transparently on its own set of pins using a sync pin to 
synchronize the beginning of transmission and reception to an external event 


e Programmable character length (4-16) 

e Reverse data mode 

e Continuous transmission and reception modes 
e Four commands 


16.11.7.2 SMC TRANSPARENT CHANNEL TRANSMISSION PROCESS. The SMC 
Transparent transmitter is designed to work with almost no intervention from the core. When 
the core enables the SMC transmitter in transparent mode, it starts transmitting idles. The 
serial management controllers immediately poll the first buffer descriptor in the transmit 
channel buffer descriptor ring and once every character time, depending on the character 
length (every 4 to 16 serial clocks). When there is a message to transmit, a serial 
management controller fetches the data from memory and starts transmitting the message 
once synchronization is achieved. 
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Synchronization can be achieved in two ways. First, when the transmitter is connected to a 


TDM channel, it can be synchronized to a time-slot. Once the frame sync is received, the 
transmitter waits for the first bit of its time-slot to occur before it starts transmitting. Data is 
only transmitted during the time-slots defined by the time-slot assigner. Secondly, when 
working with its own set of pins, the transmitter starts transmitting when the SMSYNx signal 


is asserted. 
When a buffer descri ptor data is com ole etely written to the transmit FIFO, the L bit is checked 


and if it is set, a serial management controller writes the message status bits into the buffer 
descriptor and clears the R bit. It then starts transmitting idles. When the end of the current 
buffer descriptor is reached and the L bit is not sét, only the R bit is cleared. In both cases, 

an interrupt is issued according to the | bit in the buffer descriptor. By appropriately setting 
the | bit in each buffer descriptor, interrupts can be generated after each buffer, a specific 

buffer, or each block is transmitted. The serial management controller then proceeds to the 
next buffer descriptor in the table. If no additional buffers have been presented to the serial 
management controller for transmission and the L bit was cleared, an underrun | is detected 


and the serial management controller begins transmitting idles. 


If the CM bit is set in the TX buffer descriptor, the R bit is not cleared, thus allowing the 
associated data buffer to be automatically retransmitted next time the communication 
processor module accesses this data buffer. For instance, if a single TX buffer descriptor is - 
initialized with the CM bit and the W bit set, the data buffer is continuously transmitted until 
you Clear the R bit of the buffer descriptor. 


16.11.7.3 SMC TRANSPARENT CHANNEL RECEPTION PROCESS. When the core 
enables the SMC receiver in transparent mode, it waits for synchronization before receiving 
data. Once synchronization is achieved, the receiver transfers the incoming data into 
memory according to the first RX buffer descriptor in the ring. Synchronization can be 
achieved in two ways. First, when the receiver is connected to a TDM channel, it can be 
synchronized to a time-slot. Once the frame sync is received, the receiver waits for the first 
bit of its time-slot to occur before reception begins. Data is only received during the 
time-slots defined by the time-slot assigner. Secondly, when working with its own set of pins, 
the receiver starts reception when the SMSYNx signal is asserted. 


When the data buffer is filled, a SMC Transparent controller clears the E bit in the buffer 
descriptor and generates an interrupt if the | bit in the buffer descriptor is set. If the incoming 
data exceeds the length of the data buffer, a serial management controller fetches the next 
buffer descriptor in the table and, if it is empty, continues transferring data to this buffer. 
descriptor associated data buffer. If the CM bit is set in the RX buffer descriptor, the E bit is 
not cleared, thus allowing the associated data buffer to be automatically overwritten next 
time the communication processor module accesses this data buffer. 


16-400 — MPC823 USER’S MANUAL MOTOROLA 


~ Communication Processor Module 


16.11.7.4 USING THE SMSYNx PIN FOR SYNCHRONIZATION. The SMSYN<x pin offers 
a method to externally synchronize a SMC Transparent channel. This method differs 
somewhat from the synchronization options available in the SCC2 and should be studied 
carefully. See Figure 16-118 for an example. 


Once the REN bit is set in the SMCMR, the first rising edge of the SMCLK signal that finds 
the SMSYNx pin low causes the SMC receiver to achieve synchronization. Data starts being 
received or latched on the same rising edge of SMCLK that latched SMSYNx. This is the 
first bit of data received. The receiver never loses synchronization again, regardless of the 
state of SMSYNx, until you clear the REN bit. 


Once the TEN bit is set in the SMCMRB,, the first rising edge of the SMCLK signal that finds 
the SMSYNx pin low causes the SMC transmitter to achieve synchronization. The SMC 
transmitter begins transmitting ones asynchronously from the falling edge of SMSYNx. After 
one character of ones is transmitted, if the transmit FIFO is loaded (the TX buffer descriptor 
is ready with data), data starts being transmitted on the next falling edge of SMCLK after 
some multiple of all-ones (preamble) characters are transmitted. If the transmit FIFO is 
loaded at some later time, the data starts transmitting after some multiple number of all-ones 
characters is transmitted. 


Note: Regardless of whether the transmitter or receiver uses the SMSYNx signal, it 
must make glitch-free transitions from high to low or low to high. Glitches on 
SMSYNx can cause a serial management controller to behave erratically. 





The transmitter never loses synchronization again, regardless of the state of SMSYNx, until 
you clear the TEN bit or issue the ENTER HUNT MODE command. 
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ae | SMSYN | | | 


ove ANON DAIS 




















SMTXD 1s ARE SENT 
TEN — SMSYN TXFIFO  FIVEis ~~ ~-FIRSTBITOF TRANSMISSION 
SET DETECTED LOADED _ ASSUME FIRST 5-BIT | COULD BEGIN 
HERE LOWHERE  APPX. CHARACTER = TRANSMIT HERE IF TX FIFO 
| HERE LENGTH — CHARACTER NOTLOADED IN 
EQUALS 5 (LSB) TIME 


SMSYN | | _ ek ws 







REN SET SMSYN FIRST BIT OF 
HERE OR DETECTED RECEIVE 
ENTER LOWHERE DATA (LSB) 
HUNT MODE. 
COMMAND 
ISSUED 


NOTES: 
1. SMCLK is an internal clock derived from an external CLKPIN or a baud rate generator. 
2. This example shows the SMC receiver and transmitter enabled separately. If the REN 
and TEN bits were set at the same time, a single falling edge of SMSYN would 
synchronize both. 


Figure 16-118. SMSYNx Pin Synchronization 


If both the REN and TEN bits are set in the SMCMR,, the first falling edge of the SMSYNx 
pin causes both the transmitter and receiver to achieve synchronization. To resynchronize 
the transmitter, the SMC transmitter can be disabled and reenabled and the SMSYNx pin 
can be used again to resynchronize the transmitter itself. Refer to 

Section 16.11.5 Disabling the SMCs On-the-Fly for a description of how to safely disable 
and reenable a serial management controller. Simply clearing and setting the TEN bit may 
not be sufficient. The receiver can also be resynchronized this way. 
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16.11.7.5 USING THE TIME-SLOT ASSIGNER FOR SYNCHRONIZATION. Thetime-slot 

assigner offers a method to internally synchronize a SMC Transparent channel without pes 
using the SMSYNx pin. This method is similar to that of the SMSYNx pin, except that the [ = 
synchronization event is not the falling edge of the SMSYNx signal, but the first time-slot for hae 
this SMC receiver/transmitter after the frame sync indication. Refer to Section 16.7 The | 
Serial Interface with Time-Slot Assigner for further information about configuring 

time-slots for the SMCs and SCC2. 


The time-slot assigner allows the SMC receiver and transmitter to be enabled 
simultaneously and synchronized separately, a capability that the SMSYNx pin does not 
provide. Refer to Figure 16-119 for an example of synchronization using the time-slot 
assigner. | 


TDM Tx SYNC | | 


TDM Tx CLOCK 





AFTER TEN IS SET, IF SMC RUNS OUT OF TX BUFFERS AND NEW ONES 
TRANSMISSION ARE PROVIDED LATER, TRANSMISSION BEGINS AT 
BEGINS HERE THE BEGINNING OF EITHER TIME-SLOT 
TDM Rx SYNC | | | 
TDM Rx CLOCK 
TDM Rx 





SMC1 SMC1 


AFTER REN IS SET 
OR AFTER ENTER HUNT 
MODE COMMAND, | 
RECEPTION | 
BEGINS HERE 


Figure 16-119. Time-Slot Assigner Synchronization 
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Once the REN bit is set in the SMCMR,, the first time-slot after frame sync causes the SMC 
receiver to achieve synchronization. Data is received immediately, but only during the. 
defined receive time-slots. The receiver continues receiving data during its defined 
time-slots until you clear the REN bit. If the ENTER HUNT MODE command is issued, the 
receiver loses synchronization, closes the current buffer, and resynchronizes to the first 
time-slot after the frame sync. 


Once the TEN bit is set in SMCMR, an SMC Transparent controller waits for the transmit 
FIFO to be loaded before trying to achieve synchronization. Once the transmit FIFO is 
loaded, synchronization and transmission begins depending on the following situations: 


° Ifa buffer is made ready when an SMC Transparent controller is enabled, then the first 
byte will be placed in time-slot 1 if the CLEN field in SMCMR is set to 8 and slot 2 if 
CLEN is set to 16. 


e Ifa buffer has an SMC Transparent controller enabled, then the first byte in the next 
buffer can appear in any time-slot associated with this channel. 


e Ifa buffer is ended with the L bit set, then the next buffer can appear in any time-slot 
associated with this channel. 


If an SMC Transparent controller runs out of transmit buffers and a new transmit buffer is 
provided later, idles are transmitted during the gap between data buffers. Data transmission 
from the later data buffer begins at the beginning of an SMC Transparent controller time-slot, 
but not necessarily the first time-slot after the frame sync. So if you want to maintain a certain 
bit alignment beginning with the first time-slot, make sure that at least one TX buffer 
descriptor is always ready and that no underrun occurs. Otherwise, the SMC Transparent 
transmitter should be disabled and reenabled. Refer to Section 16.11.5 Disabling the 
SMCs On-the-Fly for a description of how to safely disable and reenable the SMC 
Transparent controller. Simply clearing TEN and setting TEN may not be sufficient. 
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16.11.7.66 SMC TRANSPARENT CONTROLLER PARAMETER RAM MEMORY MAP. 
There is no protocol-specific parameter RAM for the SMC Transparent controller. Only the 
general SMC parameter RAM is used, which is discussed in more detail in 

Section 16.11.4 SMC General Parameter RAM Memory Map. 


16.11.7.7 SMC TRANSPARENT COMMANDS. You can program the CPM command 
register (CPCR) with the following commands to transmit data. 


e STOP TRANSMIT—After the hardware or software is reset and the channel is enabled 
in the SMCM-Transparent register, the channel is in the transmit enable mode and 
starts polling the first buffer descriptor in the table. This command disables the 
transmission of frames on the transmit channel. If the transparent controller receives 
this command while transmitting a frame, it stops after the contents of the FIFO are 
transmitted (up to 2 characters). The TBPTR is not advanced to the next buffer 
descriptor, no new buffer descriptor is accessed, and no new buffers are transmitted for 
this channel. The transmitter sends idles until the RESTART TRANSMIT command ts 
issued. 


e RESTART TRANSMIT—This command is used to begin or continue transmission from 
the current TBPTR in the channel’s TX buffer descriptor table. When the channel 
receives this command, it starts polling the R bit in the TX buffer descriptor. A serial 
management controller expects this command after a STOP TRANSMIT command is 
issued and the channel in the SMCMR is disabled or after a transmitter error occurs. 


e INIT TX PARAMETERS—This command initializes all the transmit parameters in this 
serial channel parameter RAM to their reset state and should only be issued when the 
transmitter is disabled. The INIT TX AND RX PARAMS command can also be used to 
reset the transmit and receive parameters. 


You can program the CPCR with the following commands to receive data. 


e ENTER HUNT MODE—This command forces a serial management controller to close 
the current receive buffer descriptor if it is currently being used and to use the next 
buffer descriptor in the list for any subsequently received data. If a serial management 
controller is not in the process of receiving data, the buffer is not closed. Additionally, 
this command causes the receiver to wait for a resynchronization before further 
reception continues. 


e CLOSE RX BD—This command is used to force a serial management controller to 
close the current receive buffer descriptor if it is being used and to use the next buffer 
descriptor in the list for any subsequently received data. If a serial management 
controller is not in the process of receiving data, no action is taken by this command. 


e INIT RX PARAMETERS—This command initializes all the receive parameters in this 
serial channel’s parameter RAM to their reset state. It should only be issued when the 
receiver is disabled. The INIT TX AND RX PARAMS command can also be used to 
reset the receive and transmit parameters. 
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16.11.7.8 SMC TRANSPARENT CONTROLLER ERRORS. The serial management 
controllers report message reception and transmission error conditions using the channel 
buffer descriptors and the SMCE—Transparent register. The following transmission errors 
can be detected by the SMC Transparent controller. 


° Underrun Error—When this error occurs, the channel stops transmitting the buffer, 


closes it, sets the UN bit in the buffer descriptor, and generates the TXE interrupt if it is 
enabled. The channel! resumes transmission after it receives the RESTART 


Mmunvit VUuU LIM Fike 2 


TRANSMIT command. Underrun cannot occur between frames. ° 


¢ Overrun Error—A serial management controller maintains an internal FIFO for 
receiving data. The communication processor module begins programming the SDMA 
channel if the data buffer is in external memory when the first character is received into 
the FIFO. If a FIFO overrun occurs, a serial management controller writes the received 
data character to the internal FIFO over the previously received character. The previous 
character and its status bits are lost. Then the channel closes the buffer, sets the OV 
bit in the buffer descriptor, and generates the RX interrupt if it is enabled. Reception 
then continues as normal. 


16.11.7.9 SMC TRANSPARENT MODE REGISTER. When the SMC is in transparent 
mode, the 16-bit, memory-mapped, read/write SMC mode register is referred to as the SMC 
transparent mode register (SMCMR-Transparent). The function of bits 8-15 is common to 
each SMC protocol, but bits 0-7 vary according to the protocol selected by the SM bits of 
this register. 


SMCMR-TRANSPARENT 





(IMMR & OxFFFFO000) + 0xA82 (suc ), 0xA92 (SMC2) 


Bits 0, 5, and 8-9—Reserved 
These bits are reserved and should be set to 0. 


~ CLEN—Character Length 


This field is programmed with a value between 3 and 15 to obtain 4 to 16 bits per character. 
If the character length is less than 8 bits, the MSBs of the byte in buffer memory are not used 


on transmit and are written with zeros on receive. On the other hand, if the character length 


is more than 8 bits but less than 16 bits, the MSBs of the half-word in buffer memory are not 
used on transmit and.are written with zeros on receive. | 
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Note: You should not write the values 0 to 2 to CLEN or else erratic behavior will occur. 
Larger character lengths increase the potential performance of the SMC channel 
and lower the performance impact of other channels. For instance, using 16-bit 
characters, rather than 8-bit characters is encouraged if 16-bit characters are 
acceptable in the end application. 





BS—Byte Sequence 


This bit controls the sequence of byte transmission if the REVD bit is set for a character 
length greater than 8 bits. It should be set to zero to maintain behavior eee with the 
MC68360 QUICC microprocessor. 


0 = Normal mode. This should be selected if the character length is less than 
or equal to 8 bits. 
1 = Transmit lower address byte first. 


REVD—Reverse Data 


0 = Normal mode. 
1= Reverse the character bit order. The MSB is transmitted first. 


SM—SMC Mode 


00 = GCI or SCIT support. 
01 = Reserved. 


10 = UART. 
11 = Totally transparent operation. This must be selected for SMC transparent 
operation. _ s 


DM—Diagnostic Mode 


00 = Normal operation. 

01 = Local loopback mode. 
10 = Echo mode. 

11 = Reserved. 


TEN—SMC Transmit Enable 


0 = SMC transmitter disabled. 
1 = SMC transmitter enabled. 


Note: Once the TEN bit is cleared, it must not be reenabled for at least 
three serial clocks. 





REN—SMC Receive Enable 


O= SMC receiver disabled. 
1 = SMC receiver enabled. 
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Communication Processor Module 


16.11.7.10 SMC TRANSPARENT RECEIVE BUFFER DESCRIPTOR. Using receive (RX) 
buffer descriptors, the communication processor module reports information about the 
received data for each buffer and closes the current buffer, generates a maskable interrupt, 
and starts to receive data into the next buffer after one of the following events occurs: 


e An overrun error occurs. 


e A full receive buffer is detected. 
e The ENTER HUNT MODE command Is issued. 


Note: The communication processor module sets all the status bits in this buffer 
descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 


re [res] w | 1 [resewen es 


RX DATA BUFFER POINTER 





NOTE: You are only responsible for initializing the items in bold. 


E—Empty 

O= The data buffer associated with this RX buffer descriptor is filled with received data 
or data reception has been aborted due to an error condition. The core Is free to 
examine or write to any fields of this RX buffer descriptor. The communication 
processor module does not use this buffer descriptor as long as the E bit is zero. 

1 = The data buffer associated with this buffer descriptor is empty or is currently _ 
receiving data. This RX buffer descriptor and its associated receive buffer are 
owned by the communication processor module. Once the E bit is set, the core 
should not write any fields of this RX buffer descriptor. 


Bits 1, 4-5, 7-13, and 15—Reserved 
These bits are reserved and should be set to 0. 
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~W—Wrap (Final Buffer Descriptor in Table) 


0 = This is not the last buffer descriptor in the RX buffer descriptor table. 

-1= This Is the last buffer descriptor in the RX buffer descriptor table. After this buffer 
is used, the communication processor module receives incoming data into the first 
buffer descriptor that RBASE points to in the table. The number of RX buffer 
descriptors in this table is programmable and determined only by the W bit and 
overall space constraints of the dual-port RAM. 


I—Interrupt 


O= No interrupt is generated after this buffer is filled. 

1 = The RX bit in the SMCE-—Transparent register is set when this buffer is completely 
filled by the communication processor module, thus indicating that the core needs 
to process the buffer. The RX bit can cause an interrupt if it is enabled. 


CM—Continuous Mode 


O = Normal operation. 

1= The E bit is not cleared by the communication processor module after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
overwritten next time the communication processor module accesses this buffer 
descriptor. However, the E bit is cleared if an error occurs during reception, 
regardless of how the CM bit is set. 


OV—Overrun 


This bit indicates that a receiver overrun has occurred during message reception. The 
communication processor module writes this bit after the received data is placed into the 
associated data buffer. 


DATA LENGTH 


This field represents the number of octets that the communication processor module writes 
into this buffer descriptor data buffer. It is written only once by the communication processor 
module as the buffer is closed. The communication processor module writes these bits after 
the received data is placed into the associated data buffer. 


| “O Note: The actual amount of memory allocated for this buffer should be greater than or 
equal to the MRBLR entry. | 


RX DATA BUFFER POINTER 


This field always points to the first location of the associated data buffer, must be even, and 
can reside in internal or external memory. The communication processor module writes 
these bits after the received data is placed into the associated data buffer. | 
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16.11.7.11 SMC TRANSPARENT TRANSMIT BUFFER DESCRIPTOR. Data is sent to 
the communication processor module for transmission on an SMC channel by arranging it 
in buffers referenced by the channel’s transmit (TX) buffer descriptor table. Using the buffer 
descriptors, the communication processor module confirms transmission or indicates error 
conditions so that the processor knows the buffers have been serviced. 





SHINES: 
AY oe 







eee ae ee 


TX DATA BUFFER POINTER 








NOTE: You are only responsible for initializing the items in bold. 


iw 4 Note: The communication processor module sets all the status bits in this buffer 

| descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 


R—Ready 

O= The data buffer associated with this buffer descriptor is not ready for transmission 
and you are free to manipulate it or its associated data buffer. The communication 
processor module clears this bit after the buffer is transmitted or after an error 
condition is encountered. 

1 = The data buffer, which you prepare for transmission, is not transmitted yet or is 
currently being transmitted. You cannot write any fields of this buffer descriptor 
once this bit is set. 


Bits 1, 5, 7-13, and 15—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Buffer Descriptor in Table) 


0 = This is not the last buffer descriptor in the TX buffer descriptor table. 
= This is the last buffer descriptor in the TX buffer descriptor table. After this buffer is 
used, the communication processor module receives incoming data into the first 
buffer descriptor that TBASE points to in the table. The number of TX buffer 
descriptors in this table is programmable and determined by the W bit and overall 
space constraints of the dual-port RAM. 
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I—Interrupt 


O= No interrupt is generated after this buffer is serviced. 
1 = The TX and TXE bits in the SMCE—Transparent register are set when this buffer is 
serviced. TX and TXE can cause interrupts if they are enabled. 


L— Last in Message 


O= The last byte in the buffer is not the last byte in the transmitted transparent frame. 
Data from the next transmit buffer (if ready) is transmitted immediately following the 
last byte of this buffer. 

1 = The last byte in this buffer is the last byte in the transmitted transparent frame. After 
this buffer is transmitted, the transmitter requires synchronization before the next 
buffer is transmitted. 


CM—Continuous Mode 


O = Normal operation. 

1 = The communication processor module does not clear the R bit after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
retransmitted next time the communication processor module accesses this buffer 


descriptor. However, the R bit will be cleared if an error occurs during transmission, 


regardless of how the CM bit is set. 


UN—Underrun 


This bit indicates that a serial management controller has encountered a transmitter _ 
underrun condition while transmitting the associated data buffer. 


DATA LENGTH 


This field represents the number of octets that the communication processor module should 
transmit from this buffer descriptor data buffer and it is never modified by the communication 
processor module. This field can be even or odd, but if the number of bits in the transparent 
character is greater than 8, this field should be even. For example, to transmit three 
transparent 8-bit characters, this field should be initialized to 3. However, to transmit three 
transparent 9-bit characters, this field should be initialized to 6 since the three 9-bit 
characters occupy three half-words in memory. 


TX DATA BUFFER POINTER 


This field always points to the first byte of the associated data buffer. They can be even or 
odd, unless the character length is greater than 8 bits, in which case this field must be even. 
For instance, the pointer to 8-bit transparent characters can be even or odd, but the pointer 
to 9-bit transparent characters must be even. The buffer can reside in internal or external 
memory. 
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Communication Processor Module 


16.11.7.12 SMC TRANSPARENT EVENT REGISTER. When the SMC is in transparent 
mode, the 8-bit memory-mapped SMC event register is referred to as the SMC transparent 
event (SMCE-—Transparent) register. It is used to generate interrupts and report events 
recognized by the SMC channel. When an event is recognized, the serial managment 
controller sets the corresponding bit in this register. Interrupts generated by this register can 
be masked in the SMCM-—Transparent register. 


A bit is cleared by writing a 1 (writing a zero has no effect) and more than one bit can be 
cleared at a time. All unmasked bits must be cleared before the communication processor 
module clears the internal interrupt request. This register is cleared at reset and can be read 
at any time. 


SMCE-TRANSPARENT 





(IMMR & OxFFFF0000) + 0xA86 (SMC1), 0xA96 (SMC2) 


Bits 0-2 and 4—Reserved 
These bits are reserved and should be set to 0. 


TXE—TX Error 
This bit indicates that an underrun error has occurred on the transmitter channel. 


BSY—Busy Condition | 
This bit indicates that a character has been received and discarded due to a lack of buffers. 


Reception begins after a new buffer is provided. You can execute an ENTER HUNT MODE 
command to make the receiver wait for resynchronization. 


TX—TX Buffer 


This bit indicates that a buffer has been transmitted. If the L bit of the TX buffer descriptor is 
set, this bit is set when the last data character starts being transmitted and you must wait 
one character time to be sure that the data is completely sent over the transmit pin. If the L 
bit of the TX buffer descriptor is cleared, this bit is set when the last data character is written 
to the transmit FIFO and you must wait two character times to be sure that the data is 
completely sent over the transmit pin. 


RX—RX Buffer 


This bit indicates that a abuffer has been received on the SMC channel and its associated 
RX buffer descriptor is now closed. This bit is set after the last character is written to the 
buffer. 
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16.11.7.13 SMC TRANSPARENT MASK REGISTER. When the SMC is in transparent 
mode, the 8-bit read/write SMC mask register is referred to as the SMC transparent mask 
(SMCM-Transparent) register. It has the same bit format as the SMCE—Transparent 
register. If a bit in this register is a 1, the corresponding interrupt in theSMCE—Transparent 
register is enabled. If the bit is zero, the corresponding interrupt is masked. 


SMCM-TRANSPARENT 










a ee 

a 

waa 
(IMMR & OxFFFFO000) + 0xA8A (SMC1), 0xA9A (SMC2) 


16.11.7.14 SMC TRANSPARENT NMSI PROGRAMMING EXAMPLE. The following is an 
example initialization sequence for SMC1 transparent channel over its own set of pins. The 
transmit and receive clocks are provided from the CLK3 pin and the SMSYN1 pin is used to 
obtain synchronization. 


1. Configure the port B pins to enable the SMTXD1, SMRXD1, and SMSYN1. Write 
PBPAR bits 25, 24, and 23 with ones and then PBDIR and PBODR bits 25, 24, and 23 
with zeros. 

2. Configure the port A pins to enable CLK3. Write PAPAR bit 5 with a one and PADIR 
bit 5 with a zero. The other functions of this pin are the timers or the time-slot assigner. 
These alternate functions cannot be used on this pin. 


3. Connect the CLK3 clock to SMC1 using the serial interface. Write the SMC1 bit in the 
SIMODE register with a 0 and the SMC1CS field in the SIMODE register with 110. 


4. Write RBASE and TBASE in the SMC parameter RAM to point to the RX buffer 
descriptor and TX buffer descriptor in the dual-port RAM. Assuming one RX buffer 
descriptor at the beginning of the dual-port RAM and one TX buffer descriptor following 
that RX buffer descriptor, write RBASE with 0x2000 and TBASE with 0x2008. 


5. Program the CPCR to execute the INIT RX AND TX PARAMS command. Write 
0x0091 to the CPCR. 


6. Write 0x0001 to the SDCR to initialize the SDMA seAibueion register. 
7. Write 0x18 to RFCR and TFCR for normal operation. 


8. Write MRBLR with the maximum number of bytes per receive buffer. Assume 16 
bytes, so MRBLR = 0x0010. 


9. Initialize the RX buffer descriptor and assume the RX data buffer is at 0x00001 000 in 
main memory. Write OxBO00 to RX_BD_Status, 0x0000 to RX_BD_Length (optional), 
and 0x00001000 to RX_BD_Pointer. 
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Communication Processor Module 


10. Initialize the TX buffer descriptor and assume the TX data buffer is at Ox00002000 in 
main memory and contains five 8-bit characters. Write OxBO00 to TX_BD _Status, 
0x0005 to TX_BD_Length, and 0x00002000 to TX_BD_Pointer. 


Cemrihaee 4 11.Write OxFF to the SMCE-Transparent register to clear any previous events. 





er 
=| 
(oO) J 


12.Write 0x13 to the SMCM-—Transparent register to enable all possible serial 
management controller interrupts. 


13. Write 0Ox00000010 to the CIMR to allow SMC1 to generate a system interrupt. The 
CICR should also be initialized. 


14.Write 0x3830 to the SMCMR to configure 8-bit characters, unreversed data, and 
normal operation (not loopback). Notice that the transmitter and receiver have not 
been enabled yet. 


15.Write 0x3833 to the SMCMR to enable the SMC transmitter and receiver. This 
additional write ensures that the TEN and REN bits are enabled last. 


~ Note: After 5 bytes are transmitted, the TX buffer descriptor is closed and after 16 bytes 
are received the receive butter is closed too. Any data received after 16 bytes 
causes a busy (out-of-buffers) condition since only one RX buffer descriptor is 
prepared. 





-16.11.7.15 SMC TRANSPARENT TSA PROGRAMMING EXAMPLE. The following is an 
example initialization sequence for the SMC1 transparent channel over the time-slot 
assigner. It is assumed that the time-slot assigner and the TDM pins have already been set 
up to route time-slot data to the SMC transmitter and receiver. Refer to Section 16.7 The 
Serial Interface with Time-Slot Assigner for examples of how to configure the time-slot 
assigner. The transmit and receive clocks and synchronization signals are provided 
internally from.the time-slot assigner. 


1. Write RBASE and TBASE in the SMC parameter RAM to point to the RX buffer 

~ descriptor and TX buffer descriptor in the dual-port RAM. Assuming one RX buffer 
descriptor at the beginning of the dual-port RAM and one TX buffer descriptor following 
that RX buffer descriptor, write RBASE with 0x2000 and TBASE with 0x2008. 


2. Program the CPCR to execute the INIT TX AND RX PARAMS command. Write 
0x0091 to the CPCR. 


3. Write 0x0001 to the SDCR to initialize the SDMA configuration register. 
4. Write 0x18 to RFCR and TFCR for normal operation. 


5. Write MRBLR with the maximum number of bytes per receive buffer. Assume 16 
bytes, so MRBLR = 0x0010. 


6. Initialize the RX buffer descriptor and assume the RX data buffer is at Ox00001000 in 
main memory. Write OxBO00 to RX_BD_Status, 0x0000 to RX_BD_Lengfth (optional), 
and 0x00001000 to RX_BD_ Pointer. 
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7. Initialize the TX buffer descriptor and assume the TX data buffer is at OxO0002000 in 
main memory and contains five 8-bit characters. Write OxBOO0O to TX_BD_ Status, 
0x0005 to TX_BD_Length, and 0x00002000 to TX_BD_Pointer. 


8. Write OxFF to the SMCE-Transparent register to clear any previous events. 


9. Write 0x13 to the SMCM-Transparent register to enable all possible serial 
management controller interrupts. 


10. Write 0x00000010 to the CIMR so that SMC1 can generate a system interrupt. The 
CICR should also be initialized. 


11.Write 0x3830 to the SMCMR-Transparent to configure 8-bit characters, unreversed 
data, and normal operation (not loopback). Notice that the transmitter and receiver are 
not enabled yet. 


12. Write 0x3833 to the SMCMR-Transparent to enable the SMC transmitter and 
receiver. This additional write ensures that the TEN and REN bits are enabled last. 


16.11.7.16 HANDLING INTERRUPTS IN THE SMC. Follow these steps to handle an 
interrupt in the serial management controller: 


1. Once an interrupt occurs, read the SMCE register to find out what caused the 
interrupts. The SMCE bits are usually cleared at this time. 


2. Process the TX buffer descriptor to reuse it if the TX bit is set in the SMCE— 
Transparent register. Extract data from the RX buffer descriptor if the RX bit is set in 
the SMCE—Transparent. To transmit another buffer, simply set the R bit in the RX 
buffer descriptor. 


3. Clear the SMC1 bit in the CISR. 
4. Execute the rfi instruction. 


16.11.8 The SMC in GCI Mode 


The serial management controller can be used to control the circuit interface and monitor 
channels of the general circuit interface (GCI) frame. When using the SCIT configuration of 
a general circuit interface, one serial management controller can handle SCIT channel 0, 
and the other serial management controller can handle SCIT channel 1. The main features 
of the SMC in GCI mode are as follows: | 


e Each SMC channel supports the circuit interface and monitor channels of the GCI 
(IOM-2) in ISDN applications | 


e Two serial management controllers support the two sets of circuit interface and monitor 
channels in SCIT channels 0 and 1 


e Full-duplex operation 
¢ Local loopback and echo capability for testing 
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Communication Processor Module 


To use the SMC GCI channels properly, the time-slot assigner in the serial interface must 
be configured to route the monitor and circuit interface channels to the serial management 
controller you prefer. Refer to Section 16.7 The Serial Interface with Time-Slot Assigner 
for more details on how to program this configuration. The SMC in GCI mode is also referred 
to as the SMC GCI controller. 


16.11.8.0.1 SMC GCI Monitor Channel Transmission Process. The monitor channel 0 
is used to exchange data wiin a layer i device (reading and wiiting internal registers ana 
transferring of the S and Q bits). Monitor channel 1 is used for programming and controlling 
voice/data modules, such as CODECs. The core writes the data byte into the transmit (TX) 
buffer descriptor. The serial management controller transmits the data on the monitor 
channel and handles the A and E control bits according to the GCI monitor channel protocol. 
You can issue the TIMEOUT command to solve deadlocks when errors in the A and E bit 
occur on the data line. 


16.11.8.0.2 SMC GCI Monitor Channel Reception Process. The serial management 
controller receives data and handles the A and E control bits according to the GCI monitor 
channel protocol. When the communication processor module stores a received data byte 
in the SMC receive (RX) buffer descriptor, a maskable interrupt is generated. You can issue 
the TRANSMIT ABORT REQUEST command and the MPC823 transmits an abort request 
on the E bit. 


16.11.8.1 HANDLING THE SMC CIRCUIT INTERFACE CHANNEL. The circuit interface 
channel is used to control the layer 1 device. The layer 2 device in the TE sends commands 
and receives indication to or from the upstream layer 1 device via circuit interface channel 
0. In the SCIT configuration, circuit interface channel 1 is used to convey real-time status 
information between the layer 2 device and nonlayer 1 peripheral devices (CODECs). 


16.11.8.1.1 SMC GCI Circuit Interface Channel Transmission Process. The core 
writes the data byte into the circuit interface TX buffer descriptor and the serial management 
controller transmits the data continuously on the circuit interface channel to the physical 
layer device. | 


16.11.8.1.2 SMC GCI Circuit Interface Channel Reception Process. The SMC receiver 
continuously monitors the circuit interface channel and when it recognizes a change in the 
data and this value is received in two successive frames, it is interpreted as valid data. This 
is referred to as the double last-look method. The received data byte is stored by the 
communication processor module in the circuit interface RX buffer descriptor and a 
maskable interrupt is generated. If the serial management controller is configured to support 
SCIT channel 1, the double last-look method is not used. 
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16.11.8.2 SMC GCI PARAMETER RAM MEMORY MAP. The SMC GCI parameter RAM 

area begins at the same offset from each SMC base area. The SMC in GCI mode has a very —— 
different parameter RAM memory map than the SMC in UART or transparent mode. In GCI ( = 
mode, the general-purpose parameter RAM contains the buffer descriptors, instead of q 
pointers, to the buffer descriptors. Compare Table 16-38 with Table 16-36 to see the 

differences. The SMC in GCI mode contains no protocol-specific parameter RAM. 


Table 16-38. SMC GCI Parameter RAM Memory Map 


OS 
[sucsese-ron [tere | voto | 
ene 
a 











SMC Base + 0C Half-word  - 
SMC Base + OE Half-word 


NOTE: You are only responsible for initializing the items in bold. | 7 | 
SMC Base = (IMMR & OxFFFFOOOO) + Ox3E80 (SMC1) and Ox3F80 (SMC2). 





e M_RXBD—The SMC monitor channel receive buffer descriptor is used by the 
communication processor module to report information about the monitor channel 
receive byte. | | | 


serene 


pe [tre [us| resewen | ATA 


NOTE: You are only responsible for initializing the items in bold. 





E—Empty 


When a serial management controller uses the monitor channel protocol, it waits until 
the core sets this bit before acknowledging the monitor channel data. 


QO= The communication processor module clears this bit to indicate that the data 
byte associated with this buffer descriptor is now available to the core. 
1=  Thecore sets this bit to indicate that the data byte associated with this buffer 


descriptor has been read. 
L—Last (EOM) 


This bit is only valid when a serial management controller implements the monitor 
channel protocol and is set when the EOM indication is received on the E bit. When this 
bit is set, the data byte is invalid. 
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Communication Processor Module 


ER—Error Condition 


This bit is only valid when a serial management controller implements the monitor 
channel protocol and is set when an error condition occurs on the monitor channel 
protocol. A new byte is transmitted before a serial management controller 
acknowledges the previous byte. 


MS—Data Mismatch 


This bit is only valid when a serial management controller implements the monitor 
channel protocol. It is set when two different consecutive bytes are received and it is 
cleared when the last two consecutive bytes match. A serial management controller 
waits for the reception of two identical consecutive bytes before wating new data to the 
RX buffer descriptor. 


Bits 4—7—Reserved 


These bits are reserved and should be set to 0. 


-DATA—Data 


This field contains the monitor channel data byte that a serial management controller 
received. 


M_TXBD—The SMC monitor channel transmit buffer descriptor is used by the 
communication processor module to report information about the monitor channel 
transmit byte. 





) AR RESERVED DATA 





INNOTE: You are only responsible for initializing the items in bold. 


R—Ready 
O= __ This bit is cleared by the communication processor module after transmission. 
The TX buffer descriptor is now available to the core. 
1=  Thecore sets this bit to indicate that the data byte associated with this buffer 


descriptor is ready for transmission. 
|—Last (EOM) 
This bit is only valid when a serial management controller implements the monitor 


channel protocol. When it is set, a serial management controller first transmits the buffer 
data and then transmits the EOM indication on the E bit. 
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AR—Abort Request 


This bit is only valid when a serial management controller uses the monitor channel a : 
protocol and it is set by a serial management controller when an abort request is ( = 
received on the A bit. The SMC transmitter transmits the EOM on the E bit after an abort SS 
request is received. 





Bits 3—7—Reserved 
These bits are reserved and should be set to 0. 


DATA—Data Field 


This field contains the data to be transmitted by a serial management controller on the 
monitor channel. 


e C/l|_RXBD—The SMC circuit interface channel receive (RX) buffer descriptor is used 
by the communication processor module to report information about the circuit interface 
channel receive byte. 





ee " 
Ep CNDATA =—SS«* RESERVED 


E—Empty 
O= The communication processor module clears this bit to indicate that the data 
byte associated with this buffer descriptor is now available to the core. 
1=  Thecore set this bit to indicate that the data byte associated with this buffer 


descriptor has been read. 


Note: Additional data received is discarded until the E bit is set. 





Bits 1-7 and 14—15—Reserved 
These bits are reserved and should be set to 0. 


C/l DATA—Command/Indication Data Bits | 


This field represents a 4-bit data field for circuit interface channel 0 and a 6-bit data field 
for circuit interface channel 1. It contains the data received from the circuit interface 
channel. For circuit interface channel 0, bits 10-13 contain the 4-bit data field and bits 
8 and 9 are always written with zeros. For circuit interface channel 1, bits 8-13 contain 
the 6-bit data field. 
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Communication Processor Module 


¢ C/l|_TXBD—The SMC circuit interface channel transmit (TX) buffer descriptor is used 
by the communication processor module to report information about the circuit interface 
channel transmit byte. | 









i 


RESERVED C/i DATA RESERVED 


R—Ready 
O= The communication processor module clears this bit after transmission to 
indicate that the buffer descriptor is now available to the core. 
1=  Thecore sets this bit to indicate that the data associated with this buffer 


_ descriptor is ready for transmission. 
Bits 1-7 and 14—15—Reserved 
These bits are reserved and should be set to 0. 


C/l DATA—Command/Indication Data Bits: 


This field represents a 4-bit data field for circuit interface channel 0 and a 6-bit data field 
for circuit interface channel 1. It contains the data to be transmitted onto the circuit 
interface channel. For circuit interface channel 0, bits 10-13 contain the 4-bit data field 
and bits 8 and 9 are always written with zeros. For circuit interface channel 1, bits 8-13 
contain the 6- bit data field. 


° TEMP1-4—These bits are used internally by the RISC microcontroller. 


16. 11.8. 3 SMC Gct COMMANDS. The following commands are issued to the CPM 
command register. 


e INIT TX AND RX PARAMS—This command initializes the transmit and receive 
parameters in the parameter RAM to their reset state and it is especially useful when 
switching protocols on a given serial channel. 


¢ TRANSMIT ABORT REQUEST—This receiver command can be issued when the 
MPC823 implements the monitor channel protocol. When it is issued, the MPC823 
sends an abort request on the A bit. 


e TIMEOUT—This transmitter command can be issued when the MPC823 implements 
the monitor channel protocol and it is usually issued because the device is not 
responding or A bit errors are detected. The MPC823 sends an abort request on the E 
bit at the time this command is issued. 
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16.11.8.4 SMC GCI MODE REGISTER. When the SMC is in GCI mode, the 16-bit, 
memory-mapped, read/write SMC mode register is referred to as the SMC GCI mode 
register (SMCMR-GCl). The functions of bits 8-15 are common to each SMC protocol, but 
bits O—7 vary according to the protocol selected by the SM bits. 


SMCMR-GCI 








(IMMR & OxFFFF0000) + 0xA82 (SMCMR1), 0xA92 (SMCMR2) 


Bits 0, 6, and 8—9—Reserved 
These bits are reserved and should be set to 0. 


CLEN—Character Length 


This field is used to define the total number of bits in the circuit interface and monitor 
channels of the SCIT channels 0 or 1. CLEN ranges from 0 to 15 and specifies values from 
1 to 16 bits. CLEN should be written with 13 for the SCIT channel 0 or GCI (8 data bits, plus 
A and E bits, plus 4 circuit interface bits = 14 bits) or with 15 for the SCIT channel 1 (8 data, 
bits, plus A and E bits, plus 6 circuit interface bits = 16 bits). 


ME—Monitor Enable 


O= Aserial management controller does not support the monitor channel. 
1 = Aserial management controller supports the monitor channel with the transparent 
or monitor channel protocol as defined in the MP bit. | 


C#—SCIT Channel Number 


O= SCIT channel 0. 
1 = SCIT channel 1. Required for Siemens ARCOFI and SGS S/T chips. 


SM—SMC Mode 


00 = GCI or SCIT support. Required for SMC GCI or SCIT operation. 
O1 = Reserved. 

10 = UART. 

11 = Totally transparent operation. 


DM—Diagnostic Mode 


OO = Normal operation. 

O01 = Local loopback mode. 
10 = Echo mode. 

11 = Reserved. 
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Communication Processor Module 


TEN—SMC Transmit Enable 


0 = SMC transmitter disabled. 
1 = SMC transmitter enabled. 


REN—SMC Receive Enable 
0 = SMC receiver disabled. 


4—~—~ CQAAC + i 
{f= SMC receiver enabled. 


16.11.8.5 SMC GCI EVENT REGISTER. When the SMC is in GCI mode, the 8-bit 
memory-mapped SMC event register is referred to as the SMC GCI event (SMCE-GCl) 
register. It is used to generate interrupts and report events recognized by the SMC channel. 
When an event is recognized, a serial management controller sets the corresponding bit in 
this register. Interrupts generated by this register can be masked in the SMCM-—GCI register. 
A bit is cleared by writing a 1 (writing a zero has no effect) more than one bit can be cleared 
at a time. All unmasked bits must be cleared before the communication processor module 
clears the internal interrupt request to the CPM interrupt controller. This register is cleared 
by reset and can be read at any time. 


SMCE-GCI 


Po fo fo fo 
aw [aw 


[e— 
a a 


(IMMR & OxFFFF0000) + 0xA86 (SMC1), 0xA96 (SMC2) 





Bits O-8—Reserved 
These bits are reserved and should be set to 0. 


CTXB—Circuit Interface Channel Buffer Transmitted 
This bit indicates that the circuit interface transmit buffer is now empty. 


CRXB—Circuit Interface Channel Buffer Received 
This bit indicates when the circuit interface receive buffer is full. 


MTXB—Monitor Channel Buffer Transmitted 
This bit indicates that the monitor transmit buffer is now empty. 


MRXB—Monitor Channel Buffer Received 
This bit indicates when the monitor receive buffer is full. 
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16.11.8.6 SMC GCI MASK REGISTER. Whe the SMC is in GCI mode, the 8-bit, 
memory-mapped, read/write SMC mask register is referred to as the SMC GCI mask 
(SMCM-—GC)) register. It has the same bit format as the SMCE-GCI register. If a bit in this 
register is a 1, the corresponding interrupt in the SMCE—GCI is enabled. If the bit is zero, 
the corresponding interrupt in the SMCE—GCI is masked. 


SMCM-GCI 


a 


(IMMR & OxFFFF0000) + 0xA8A (SMC1), OxA9A(SMC2) 





16.12 THE SERIAL PERIPHERAL INTERFACE 


The serial peripheral interface (SPI) allows the MPC823 to exchange data between other 
MPC8xx Family chips, the MC68328, MC68360, and MC68302 embedded 
microprocessors, as well as the MC68HC11 and MC68HC05 microcontroller families and a 
variety of peripheral devices. 


The serial peripheral interface is a full-duplex, synchronous, character-oriented channel that 
supports a four-wire interface (receive, transmit, clock and slave select). The SPI block 
consists of transmitter and receiver sections, an independent baud rate generator, and a 
control unit. The transmitter and receiver sections use the same clock, which is derived from 
the SPI baud rate generator in master mode and generated externally in slave mode. During 
an SPI transfer, data is transmitted and received simultaneously. 


Becuase the SPI receiver and transmitter are double-buffered, as illustrated in the block 
diagram below, the effective FIFO size is 2 characters. You can program the MPC823 serial 
peripheral interface to shift out the most- or least-significant bit first. When the serial 
peripheral interface is not enabled in the SPMODE register, it consumes very little power. 
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| ws 





IMB PERIPHERAL BUS 





SPISEL SPIMOS!| —_-SPIMISO SPICLK 


Figure 16-120. SPI Block Diagram 


16.12.1 Features 


The following is a list of the serial peripheral interface’s main features: 


¢ Four-Wire Interface (SPIMOSI, SPIMISO, SPICLK, and SPISEL) 
¢ Full-Duplex Operation | 

¢ Works with Data Characters from 4 to 16 bits Long | 

e Supports Back-to-Back Character Transmission and Reception 
Master or Slave SPI Modes Supported 

Multimaster Environment Support 


Continuous Transfer Mode for Autoscanning Peripherals 


e Supports maximum Clock Rates of 6.25MHz in Master Mode and 12.5MHz in Slave 
Mode, Assuming a 25MHz System Clock is Used 


e Independent Programmable Baud Rate Generator 

e Programmable Clock Phase and Polarity 

¢ Open-Drain Output Pins Support Multimaster Configuration 
e Local Loopback Capability for Testing 
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16.12.2 SPI Clocking and Pin Functions 


You can configure the serial peripheral interface as a master for the serial channel or as a 
slave. You can also use it in a multimaster environment. When the serial peripheral interface 
is a master, use the SPI baud rate generator to generate the SPI transmit and receive 
clocks. It takes its input from the BRGCLK, which is generated in the clock synthesizer of 
the MPC823, specifically for the SPI baud rate generator and the other three baud rate 
generators in the communication processor module. 


The SPIMISO pin is an input in master mode and an output in slave mode. It follows then, 
that the SPIMOSI pin is an output in master mode and an input in slave mode. The reason 
the pin names SPIMOSI and SPIMISO change functionality between master and slave 
mode is to support a multimaster configuration that allows communication from one serial 
peripheral interface to another with the same hardware configuration. 


When the serial peripheral interface is in master mode, SPICLK is the clock output signal 
that shifts in the received data from the SPIMISO pin and shifts out the transmitted data to 
the SPIMOSI pin. Additionally, an SPI master device must provide a slave select signal 
output to enable the SPI slave devices. You can implement this by using one of the MPC823 
general-purpose I/O pins. The SPISEL pin should not be asserted while the serial peripheral 
interface is in master mode or an error will occur. 





When the serial peripheral interface is in slave mode, SPICLK is the clock input signal that 
shifts in the received data from the SPIMOSI pin and shifts out the transmitted data to the 
SPIMISO pin. The SPISEL pin provided by the MPC823 is the enable input to the SPI slave. 
When the serial peripheral interface is operating in a multimaster environment, the SPISEL 
pin is still an input and is used to detect an error condition when more then one master is 
operating. 








Using the fields in the SPI mode register, you can select any of the four combinations of the 
gated SPICLK phase and polarity. The SPI pins can also be configured as open-drain pins 
to support a multimaster paron in which the same SPI pin is driven by the MPC823 
or an external SPI device. 
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Communication Processor Module 


16.12.3 The SPI Transmission and Reception Process 


When the serial peripheral interface is in master mode, it transmits a message to the 


peripheral or slave, which sends back an immediate reply. When the MPC823 has more 


than one slave, it can use the general-purpose parallel I/O pins to selectively enable different 
slaves. To start the data exchange process, the core writes the data to be transmitted into 
a data buffer, configures a TX buffer descriptor with its R bit set, and configures one or more 


AX butler Gescriptors. Tne core then seis the STR bit in the SPCOM register to start — 
transmitting data, which starts when the SDMA channel loads the transmit FIFO with data. 


The serial peripheral interface then generates programmable clock pulses on the SPICLK 


pin for each character and shifts the data out on the SPIMOSI pin. At the same time, the 
serial peripheral interface shifts received data in from the SPIMISO pin. This received data 
is written into a receive buffer using the next available RX buffer descriptor. The serial 
peripheral interface continues transmitting and receiving characters until the transmit buffer 
has been completely transmitted or an error has occurred. The communication processor 
module then clears the R and E bits in the TX buffer descriptor and RX buffer oe cupee and 
may issue a maskable interrupt to the CPM interrupt controller. 


When multiple TX buffer descriptors are ready to be transmitted, the TX buffer descriptor L 


bit determines whether or not the serial peripheral interface should continue transmitting 
without waiting for the STR bit to be set again. If the L bit is cleared, the data from the next 


_ TX buffer descriptor begins transmitting after data from the first TX buffer descriptor is 

transmitted. If the L bit is set, transmission stops after data from this TX buffer descriptor has — 

_ finished transmitting. In addition, the current RX buffer descriptor that is used to receive data 
_ is closed after transmission stops, even if the receive buffer is not full. This means that you 


do not need to provide receive buffers that are the same length as the transmit buffers. If the 
serial peripheral interface is the only master in a system, then the SPISEL pin can be used 
as a general-purpose I/O, and the internal SPISEL signal to the serial peripheral interface is 
always forced internally inactive, thus eliminating the possibility of a multimaster error. 








When the serial peripheral interface is in slave mode, it receives messages from an SPI 





master and sends back a simultaneous reply. The SPISEL pin must be asserted before 
receive clocks are recognized and once SPISEL is asserted, the SPICLK pin becomes an 
input from the master to the slave. SPICLK can be any frequency from the DC to the 
BRGCLK/2, which is 12.5MHz for a 25MHz system. 





Before the data is exchanged, the core writes the data to be transmitted into a data buffer, 
configures a TX buffer descriptor with its R bit set, and configures one or more RX buffer 
descriptors. The core then sets the STR bit in the SPCOM register to enable the serial 
peripheral interface so it will prepare the data for transmission and wait for the SPISEL pin 
to be asserted. Data is shifted out from the slave on the SPIMISO pin and shifted in through 
the SPIMOSI pin. A maskable interrupt is issued when a full buffer finishes receiving and 
transmitting or after an error occurs. Using the next RX buffer descriptor in the ring, the serial 
peripheral interface continues reception until it runs out of receive buffers or the SPISEL pin 
is negated. 
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Transmission continues until no more data is available or the SPISEL pin is negated. If the 
pin is negated before all the data is transmitted, it stops, but the TX buffer descriptor stays 
open. Further transmission continues once the SPISEL pin is reasserted and SPICLK 
begins toggling. After the characters in the TX buffer descriptor are transmitted, the serial 
peripheral interface transmits ones if SPISEL is not negated. 








16.12.3.1 MULTIMASTER OPERATION. The serial peripheral interface can operate ina 
multimaster environment in which some SPI devices are connected to the same bus. In this 
configuration, the SPIMOSI, SPIMISO, and SPICLK pins of all SPls are connected together 
and the SPISEL input pins are connected separately. In this environment, only one SPI 
device can be in master mode and all the others must be in slave mode. When the serial 
peripheral interface is configured as a master and its SPISEL signal goes active or low, a 
multimaster error will occur because more than one SPI device is a bus master. The serial 
peripheral interface sets the MME bit in the SPIE register and a maskable interrupt is issued 
to the core. It also disables SPI operation and the output drivers of the SPI pins. The core 
should clear the EN bit the SPMODE register before using the serial peripheral interface 
again. After the problems are corrected, clear the MME bit and enable the serial peripheral 
interface the same way you would after a reset. 








Note: The maximum sustained data rate that the serial peripheral interface supports is 
SYSTEMCLK/50. However, the serial peripheral interface can transfer a single 
character at much higher rates. For instance, SYSTEMCLK/4 in master mode 
and SYSTEMCLK/2 in slave mode. If multiple characters are to be transmitted, 
you should insert gaps between them so that it will not exceed the maximum 
sustained data rate. 
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Seal 16.12.3.2 SPI PARAMETER RAM MEMORY MAP. The SPI parameter RAM area begins 
at the SPI base address and is used for the general SPI parameters. Notice that it is similar 
to the SCC2 general-purpose parameter RAM. You must initialize certain parameter RAM 
values before the serial peripheral interface is enabled. The communication processor 
module initilizes the other values. Once initialized, the parameter RAM values do not usually 
need to be accessed by your software. They should only be modified when there is no serial 
peripheral interface activity in progress. 


Table 16-39. SPI Parameter RAM Memory Map 


rooness [wane [wore | —_—oesonnow 


NOTE: You are only responsible for initializing the items in bold. 
SPI Base = (IMMR & OxFFFFOO00) + 0x3D80. 
SCC2 Ethernet parameter RAM space overlaps the SPI parameter RAM space. The address range 
for SCC2 space is 0x1000 through 0x1CA3. You need a microcode patch to run SPI and Ethernet 
concurrently. 





e RBASE and TBASE—The receive and transmit buffer descriptor base address entries 
are where the dual-port RAM starts receiving and transmitting data for the RX and TX 
buffer descriptors. They provide a great deal of flexibility in how buffer descriptors for a 
serial peripheral interface are partitioned. You must initialize these entries before 
enabling the corresponding channel. You should not configure the SPI buffer descriptor 
tables to overlap with the tables of the USB, SMC, and SCC or erratic operation will 
occur. RBASE and TBASE should contain a value that is divisible by eight. 
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e RFCR and TFCR—Threceive and transmit function code register entries contain the 
value that you want to appear on the AT pins when the associated SDMA channel 
accesses memory. This register controls the byte-ordering convention used in the 
transfers. 


RFCR 










a 
SPI BASE + 0x04 


Bits O-2—Reserved 
These bits are reserved and should be set to 0. 


BO—Byte Ordering 
You should set these bits to select the required byte ordering of the data buffer. 


00 


The DEC/Intel convention is used for byte ordering (swapped operation) and 
is also called little-endian byte ordering. The transmission order of bytes within 
a buffer word is reversed in comparison to the Motorola mode. This mode | is 
supported only for 32-bit port size memory. 

PowerPC little-endian byte ordering. As data is transmitted onto the serial line 
from the data buffer, the least-significant byte of the buffer double-word 
contains data to be transmitted earlier than the most- “significant byte of the 
same buffer double-word. | 

Motorola byte ordering (normal operation) is also called big-endian byte 
ordering. As data is transmitted onto the serial line from the data buffer, the 
most-significant byte of the buffer word contains data to be transmitted earlier 
than the least-significant byte of the same buffer word. 


AT—Address Type 1-3 


These bits contain the function code value used during the SDMA channel memory 
access. ATO is driven with a 1 to identify this SDMA channel access as a DMA-type 
access. 


01 


1X 


TFCR 










SPI BASE + 0x05 
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lial. 


as Bits O-2—Reserved 
These bits are reserved and should be set to 0. 





BO—Byte Ordering 


You should set these bits to select the required byte ordering of the data buffer. If this 
bit field is modified on-the-fly, it takes effect at the beginning of the next frame or at the 


+ Ar ff al + 
beginning of the next buffer descriptor. | 


00= The DEC/Intel convention is used for byte ordering (swapped operation) and 
is also called little-endian byte ordering. The transmission order of bytes within 
a buffer word is reversed in comparison to the Motorola mode. This mode is 
supported only for 32-bit port size memory. 

01= PowerPC little-endian byte ordering. As data is transmitted onto the serial line 
from the data buffer, the least-significant byte of the buffer double-word 
contains data to be transmitted earlier than the most- significant byte of the 
same buffer double-word. 

1X = Motorola byte ordering (normal operation) is also called big-endian byte 
ordering. As data is transmitted onto the serial line from the data buffer, the 
most-significant byte of the buffer word contains data to be transmitted earlier 
than the least-significant byte of the same buffer word. 


AT—Address Type 1-3 


These bits contain the function code value used during the SDMA channel memory 
access. ATO is driven with a 1 to identify this SDMA channel access as a DMA-type 
access. 


e MRBLR—The serial peripheral interface has one maximum receive buffer length entry 
_ to define its receive buffer length and it defines the maximum number of bytes that the 
MPC823 writes to a receive buffer on the serial peripheral interface before moving to 
the next buffer. The MPC823 can write fewer bytes to the buffer than the MRBLR value 
if an error or end-of-frame occurs, but it never writes more bytes than the MRBLR value. 
Buffers you supply for the MPC823 to use should always be at least as long as MRBLR. 


The transmit buffers for a serial peripheral interface are not affected by the value you 

program into MRBLR and they can be individually chosen to have varying lengths, as 

needed. You choose the number of bytes to be transmitted by programming the DATA 
~ LENGTH field in the TX buffer descriptor. 


MRBLR is not intended to be dynamically changed while a serial peripheral interface is 
operating. However, if it is modified in a single bus cycle with one 16-bit move (not two 
8-bit bus cycles back-to-back), a dynamic change in receive buffer length can be 
successfully achieved. This occurs when the communication processor module moves 
control to the next RX buffer descriptor in the table. Thus, a change to MRBLR does not 
have an immediate effect. To guarantee the exact RX buffer descriptor on which the 
change occurs, you should only change MRBLR while the SPI receiver is disabled. The 
MRBLR value should be greater than zero and should be even if the character length 
of the data is greater than 8 bits. 
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° RRBPTR—The RX buffer descriptor pointer entry for each SPI channel points to the 
next buffer descriptor that the receiver transfers data to when it is in an idle state or to 
the current buffer descriptor during frame processing. After a reset or when the end of 
the buffer descriptor table is reached, the communication processor module initializes 
this pointer to the value programmed in the RBASE entry. Although in most applications 
you should not write RBPTR, it can be modified when the receiver is disabled or when 
you are sure that no receive buffer is currently in use. 


e TBPTR—The TX buffer descriptor pointer entry for each SPI channel points to the next 
buffer descriptor that the transmitter transfers data from when it is in an idle state or to 
the current buffer descriptor during frame transmission. After a reset or when the end 
of buffer descriptor table is reached, the communication processor module initializes 
this pointer to the value programmed in the TBASE entry. Although in most applications 
you should not write TBPTR, it can be modified when the transmitter is disabled or when 
you are sure that no transmit buffer is currently in use. 


e Other General Parameters—For normal operation, you do not need to access these 
parameters. They are only listed here because they provide helpful information for 
experienced users and they can be used for debugging purposes. Additional 
parameters are listed in Table 16-39. RPTR and TPTR are updated by the SDMA 
channels to show the next address in the buffer to be accessed. TCNT is a down-count 
value initialized with the TX buffer descriptor data length and decremented with every 
byte read by the SDMA channels. The RCNT is a down-count value that is initialized 
with the MRBLR value and decremented with every byte the SDMA channels write. The 
RSTATE, TSTATE, RTMP, TMP, and reserved areas can only be used by the RISC 
microcontroller. 


Note: To extract data from a partially full buffer, use the CLOSE RX BD command. 





16.12.3.3 SPI COMMANDS. The following transmit and receive commands are issued to 
the CPM command register (CPCR). 


° INIT TX PARAMETERS—This command initializes all transmit parameters in this serial 
channel parameter RAM to their reset state and should only be issued when the 
transmitter is disabled. The INIT TX AND RX PARAMS command can also be used to 
reset the transmit and receive parameters. 


e CLOSE RX BD—This command is used to force the SPI controller to close the current 
RX buffer descriptor if it is currently being used and to use the next buffer descriptor for 
any subsequently received data. If the SPI controller is not in the process of receiving 
data, no action is taken by this command. 


e INIT RX PARAMETERS—This command initializes all the receive parameters in this 
serial channel parameter RAM to their reset state and should only be issued when the 
receiver is disabled. The INIT TX AND RX PARAMS command can also be used to 
reset the receive and transmit parameters. 
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16.12.3.4 SPi BUFFER DESCRIPTOR RING. The data associated with the serial 
peripheral interface is stored in buffers, which are referenced by buffer descriptors 
organized in a buffer descriptor ring located in the dual-port RAM. This ring has the same 
basic configuration as the SCC2, SMC, USB, and I°C controllers. 


The buffer descriptor ring forms a circular queue that helps you arrange the buffers you want 
to transmit or receive. Using the buffer descriptors, the communication processor module 
confirms reception and transmission or indicates error conditions so that the processor 
knows the buffers have been serviced. The actual buffers can reside in either external 
memory or internal memory and the data buffers can reside in the parameter area of another 
unused controller if it is not enabled. 


DUAL-PORT RAM EXTERNAL MEMORY 


TX DATA BUFFER 
TX DATA BUFFER 


POINTER TO SPI 
TX RING 
ee el 


POINTER TO SPI 
RING 


RX 

















maa 







FRAME STATUS 
DATA LENGTH 
DATAPOINTER = 


RX BD RING 


, FRAME STATUS 
DATA LENGTH : 


DATAPOINTER 


RX DATA BUFFER 


Figure 16-121. SP| Memory Format 
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16.12.4 Programming the Serial Peripheral Interface 


16.12.4.1 SPI MODE REGISTER. The read/write SPI mode (SPMODE) register controls 
both the serial peripheral interface operation mode and clock source. Table 16-2 contains 
more information on commands that can be used with this register. 


SPMODE 


(IMMR & OxFFFFO000) + OxAAO 





Bit O—Reserved 
This bit is reserved and should be set to 0. 


LOOP—Loop Mode 


When set, this bit selects the local loopback operation. The transmitter output is internally 
connected to the receiver input. The receiver and transmitter operate normally, except that 
the externally received data is ignored. 


O = Normal operation. i 
1 = The serial peripheral interface is in loopback mode. 


Cl—Clock Invert 
This bit inverts the SPI clock polarity. See Figure 16-122 and Figure 16-123 for details. 


O= The inactive state of SPICLK is low. 
= The inactive state of SPICLK is high. 


CP—Clock Phase 


This bit selects one of two fundamentally different transfer formats. See Figure 16-122 and 
Figure 16-123 for details. 


0= SPICLK starts toggling at the middle of the data transfer. 
1 = SPICLK starts toggling at the beginning of the data transfer. 


DIV16—Divide by 16 


This bit selects the clock source for the SPI baud rate generator when configured as an SPI 
master. In slave mode, the clock source is the SPICLK pin. 


0 = Use the BRGCLK as the input to the SPI baud rate generator. 
1 = Use the BRGCLK/16 as the input to the SPI baud rate generator. 
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REV—Reverse Data 
This bit determines the receive and transmit character bit order. 


0= Reverse data. Least-significant bit of the character transmitted and received first. 
1 = Normal operation. Most-significant bit of the character transmitted and received 
first. 


M/S—Master/Slave | 
This bit configures the serial peripheral interface to operate as a master or slave. 


O= The serial peripheral interface is a slave. 
1 = The serial peripheral interface is a master. 


EN—Enable SPI 


This bit enables serial peripheral interface operation. Configure the SPIMOSI, SPIMISO, 
SPICLK, and SPISEL to connect to the serial peripheral interface as described in 

Section 16.14.6 The Port B Registers. When the EN bit is cleared, the serial peripheral 
interface is in a reset state and consumes minimal power, which means the SPI baud rate 
generator is not functioning and the input clock is disabled. 





0 = The serial peripheral interface is disabled. 
1= The serial peripheral interface is enabled. 


7 4 Note: You should not do other bits of the SEMODE register when the EN bit is set. 


LEN—Character Length 


This field specifies the number of bits in a character. These values must be between 4 and 
16 bits. If you program a value less than 4 bits, erratic behavior will occur. If the value of LEN 
is less than or equal to a byte, there will be LEN number of valid bits in every byte (8 bits) in 
memory. On the other hand, if the value of LEN is greater than a byte, there is LEN number 
of valid bits in every half-word (16 bits) in memory. 


0011 = 4-bit character length. 
0100 = 5-bit character length. 
0101 = 6-bit character length. 
0110 = 7-bit character length. 
0111 = 8-bit character length. 


1111 = 16-bit character length. 
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PM—Prescale Modulus Select 


This field specifies the divide ratio of the prescale divider in the SPI clock generator. The 
BRGCLK is divided by 4 * ([PMO—PM3] + 1), thus giving a clock divide ratio of 4 to 64. The 
clock has a 50% duty cycle. 


16.12.4.1.1 SPI Examples With Different LEN Values. The programming examples 
below illustrate the effect of the LEN field and the REV bit in the SPMODE register on output 
from the SPI controller. They illustrate the master mode output from the SPI controller as the 
LEN varies. To help map the output process, make g through v the binary symbols, use x to 
indicate a deleted bit, use ___ to indicate original byte boundaries, and use _ to indicate 
original nibble (4-bit) boundaries. 


The initial pattern for all examples is ghij_klmn__opqr_stuv. 


Example 1 LEN = 0x4 (Data Size = 5) 


Data Selected: 


Data Transmitted for REV=0: 
Data Transmitted for REV=1: 


Example 2 LEN = 0x7 
Data Selected: 


Data Transmitted for REV=0: 
Data Transmitted for REV=1: 


Example 3 LEN = Oxc 


Data Selected: 


Data Transmitted for REV=0: 
Data Transmitted for REV=1: 


Example 4 | LEN = Oxf 
Data Selected: 


Data Transmitted for REV=0: 
Data Transmitted for REV=1: 


MOTOROLA 


xxxj_klmn_xxxr_stuv 
mnmlk_j.__vuts_r 
j_nmlk__r_stuv 


(Data Size = 8) 
ghij_klmn_opqr_stuv 
nmlk_jihg__vuts_rqpo 
ghij_klmn__opqr_stuv 


(Data Size = 13) 
ghij_klmn_xxxr_stuv 
nmlk jihg__vuts_r 
r_stuv__ghij_klmn 


(Data Size = 16) 
ghij_klmn_opgqr_stuv 
nmlk_jihg__vuts_raqpo 
opqr_stuv__ghij_klmn 
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SPICLK 











SPICLK 
SPIMOSI SB | 
eno, —{— ws XXX XXX X- 


NOTE: Q = Undefined Signal 


Figure 16-122. SPi Transfer Format If CP = 0 


SPICLK = (Cl = 0) 

Ls 

SPICLK  (Cl=1) a 
iene Cee XX XXX 0} 
[FROM SLAVE Ca KwseX XX X X XX XK ise?) 


SPISEL 





NOTE: Q = Undefined Signal 


Figure 16-123. SPI Transfer Format If CP = 1 
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16.12.4.1.2 SPI Receive Buffer Descriptor. Using receive (RX) buffer descriptors, the 
communication processor module reports information about each buffer of received data, 
closes the current buffer, generates a maskable interrupt, and starts receiving data in the 
next buffer once the current buffer is full. Additionally, it closes the buffer when the serial 
peripheral interface is configured as a slave and the SPISEL pin goes inactive, thus 
indicating that the reception process has stopped. 


The first word of the RX buffer descriptor contains status and control bits that you prepare 
before reception and then the communication processor module sets them after the buffer 
is closed. The second word contains the data length (in bytes) that is received and the third 
and fourth words contain a pointer that always points to the beginning of the received data 
buffer. You should configure the RX buffer descriptor bits before the serial peripheral 
interface is enabled. 











re[eesfw]t[ufres/ou[ reseed | vue 


| RX DATA BUFFER POINTER 


NOTE: You are only responsible for initializing the items in bold. 





Note: The communication processor module sets all the status bits in this buffer 
descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. FOr exompe the parity error 
bit is only set when a parity error occurs. 





E—Empty 

O= The data buffer associated with this RX buffer descriptor is filled with data or stops 
receiving data because an error occurred. The core is free to examine or write to 
any fields of this RX buffer descriptor, but it does not use this buffer descriptor as 
long as the E bit is zero. | 

1 = The data buffer associated with this buffer descriptor is empty or is currently 
receiving data. This RX buffer descriptor and its associated receive buffer are 
owned by the communication processor module. Once the E bit is set, the core 
should not write any fields of this RX buffer descriptor. 


Bit 1, 5, and 7—13—Reserved | 
These bits are reserved and should be set to O. 
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W—Wrap (Final Buffer Descriptor in Table) 


O= This is not the last buffer descriptor in the RX buffer descriptor table. 

v = This is the last buffer descriptor in the RX buffer descriptor table. After this buffer 
is used, the communication processor module receives incoming data into the first 
buffer descriptor that RBASE points to in the table. The number of RX buffer 
descriptors in this table is programmable and determined only by the W bit and 
overall space constraints of the dual-port RAM. 


I—Interrupt 


QO No interrupt is generated after this buffer is filled. 

1 The RXB bit in the SPIE register is set when this buffer is completely filled by the 
communication processor module, indicating the need for the core to process the 
buffer. The RXB bit can cause an interrupt if it is enabled. 


CM—Continuous Mode 


This bit is valid only when the serial peripheral interface is in master mode. In slave mode, 
it should be written as a zero. 


O = Normal operation. 

1= The E bit is not cleared by the communication processor module after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
overwritten next time the communication processor module accesses this buffer 
descriptor. This allows continuous reception from an SPI slave into one buffer for 
autoscanning of a serial A/D peripheral with no core overhead. 


|—Last 


This bit is set by the serial peripheral interface when the buffer is closed because the 
SPISEL pin was negated. This only occurs when the serial peripheral interface is in slave 
mode. Otherwise, the ME bit is set. The serial peripheral interface writes this bit after the 
received data is placed into the associated data buffer. 





O= This buffer does not contain the last character of the message. 
1 = This buffer contains the last character of the message. 


OV—Overrun 

This bit indicates that a receiver overrun has occurred during reception. This can only occur 
when the serial peripheral interface is in slave mode. The serial peripheral interface writes 
this bit after the received data is placed into the associated data buffer. 


ME—Multimaster Error 

This bit indicates that this buffer is closed because the SPISEL pin was asserted when the 
serial peripheral interface was in master mode. This indicates a synchronization problem 
between multiple masters on the SPI bus. The serial peripheral interface writes this bit after 
the received data is placed into the associated data buffer. 
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DATA LENGTH 


This field represents the number of octets that the communication processor module writes 
into this buffer descriptor data buffer. The communication processor module writes it once 
as the buffer descriptor is closed. The serial peripheral interface writes these bits after the 
received data is placed into the associated data buffer. The actual amount of memory 
allocated for this buffer should be greater than or equal to the MRBLR. 


RX DATA BUFFER POINTER 


This field always points to the first location of the associated data buffer, must be even, and 
can reside in internal or external memory. The serial peripheral interface writes these bits 
after the received data is placed into the associated data buffer. 


16.12.4.1.3 SPI Transmit Buffer Descriptor. Data to be transmitted with the serial 
peripheral interface is sent to the communication processor module by arranging it in buffers 
referenced by the transmit (TX) buffer descriptor ring. The first word of the TX buffer 
descriptor contains status and control bits. You should prepare the following bits before 
transmitting data. 


Cec mame gas ca 


- DATALENGTH | | 


TX DATA BUFFER POINTER 





NOTE: You are only responsible for initializing the items in bold. 


wr Note: The communication processor module sets all the status bits in this buffer 
| | descriptor. You should clear all the status bits before submitting the buffer 
| descriptor to the communication processor module. For example, the parity error 

bit is only set when a parity error occurs. | 


R—Ready 

O= The data buffer associated with this buffer descriptor is not ready for transmission 
and you are free to manipulate this buffer descriptor or its associated data buffer. 
The communication processor module clears this bit after the buffer is transmitted 
or after an error occurs. 

1 = The data buffer, which you prepare for transmission, is not transmitted yet or is 
currently being transmitted. You cannot write any fields of this buffer descriptor 
once this bit is set. 
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Bits 1, 5, and 7—13—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Buffer Descriptor in Table) 


0 = This is not the last buffer descriptor in the TX buffer descriptor table. 

1 = This is the last buffer descriptor in the TX buffer descriptor table. After this buffer is 
used, the communication processor module receives incoming data into the first 
buffer descriptor that TBASE points to in the table. The number of TX buffer 
descriptors in this table is programmable and determined only by the W bit and 


overall space constraints of the dual-port RAM. 


I—Interrupt 


0 = No interrupt is generated after this buffer is serviced. 
1 = The TXB or TXE bit in the event register is set when this buffer is serviced. TXB 
and TXE can cause interrupts if they are enabled. 


|—Last 


0 = This buffer does not contain the last character of the message. 
1 = This buffer contains the last character of the message. 


CM—Continuous Mode 


This bit is only valid when the serial peripheral interface is in master mode. In slave mode, 
it should be written as a zero. | 


0= Normal operation. 

1 = The R bit is not cleared by the communication processor module after this buffer 
descriptor is closed, thus allowing the associated data buffer to be automatically 
retransmitted next time the communication processor module accesses this buffer 
descriptor. 


UN—Underrun 


This bit indicates that the serial peripheral interface has encountered a transmitter underrun 
condition while transmitting the associated data buffer. This error condition is only valid 
when the serial peripheral interface is in slave mode. The serial peripheral interface writes 
this bit after it finishes transmitting the associated data buffer. 


ME—Multimaster Error 
This bit indicates that this buffer is closed because the SPISEL pin was asserted when the 


serial peripheral interface was in master mode. This indicates a synchronization problem 


between multiple masters on the SPI bus. The serial peripheral interface writes this bit after 
it finishes transmitting the associated data buffer. 
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DATA LENGTH 


This field indicates the number of octets that the communication processor module should 
transmit from this buffer descriptor data buffer. However, it is never modified by the ~ 
communication processor module. Normally, this value should be greater than zero, but if 
the number of data bits in the character is greater than 8, then the data length should be 
even. For example, to transmit three characters of 8-bit data, 1 start, and 1 stop, the data 
length field should be initialized to 3. However, to transmit three characters of 9-bit data, the 
DATA LENGTH field should be initialized to 6 since the three 9-bit data fields occupy three 
half-words in memory. The serial peripheral interface writes these bits after it finishes 
transmitting the associated data buffer. 


TX DATA BUFFER POINTER 


This field always points to the first location of the associated data buffer. They can be even 
or odd, unless the number of actual data bits in the character is greater than 8 bits, in which 
case the transmit buffer pointer must be even. The buffer can reside in internal or external 
memory. The serial peripheral interface writes these bits after it finishes transmitting the 
associated data buffer. 


16.12.4.2 SPI COMMAND REGISTER. The 8-bit read/write SP! command (SPCOM) 
register is used to start serial peripheral interface operation. 





(IMMR & OxFFFF0000) + OxAAD 


STR—Start Transmit 


When the serial peripheral interface is configured as a maior setting this bit to 1 causes 
the serial peripheral interface to start transmitting and receiving data to and from the 
transmit/receive buffers if they are ready. When the serial peripheral interface is in slave 
mode, setting the STR bit to 1 when the serial peripheral interface is idle causes the serial 
peripheral interface to load the transmit data register from the SPI transmit buffer and start 
transmission as soon as the next SPI input clocks and select signal are received. This bit is 
automatically cleared after one system clock cycle. 


Bits 1-7—Reserved. 
These bits are reserved and should be set to 0. 
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16.12.4.3 SPIl EVENT REGISTER. The 8-bit memory-mapped SPI event (SPIE) register is 
used to generate interrupts and report events recognized by the serial peripheral interface. 
When an event is recognized, the serial peripheral interface sets its corresponding bit in this 
register. Interrupts generated by this register can be masked in the SPIM register. A bit is 
cleared by writing a 1 (writing a zero has no effect) and more than one bit can be cleared at 
a time. However, all unmasked bits must be cleared before the communication processor 
module clears the internal interrupt request. This register is cleared by reset and can be read 
at any time. | 


SPIE 


RESERVED 


p> Pe fo Po fo ff 


(IMMR & OxFFFFO000) + OxAA6 





Bits 0-1 and 4—Reserved 
These bits are reserved and should be set to 0. 


MME—Multi-Master Error 


This bit indicates that the serial peripheral interface has found out that the SPISEL pin was 
asserted externally while the serial peripheral interface was in master mode. 


TXE—TX Error 
This bit indicates that an error has occurred during transmission. 


BSY—Busy Condition 


This bit indicates that received data has been discarded due to a lack of buffers. This bit is 
set after the first character is received for which there is no receive buffer available. 


TXB—TX Buffer 


This bit indicates that a buffer has been transmitted. It is set once the transmit data of the 
last character in the buffer is written to the transmit FIFO. You must wait two character times 
to be sure that the data is completely sent over the transmit pin. 


RXB—RX Buffer 


This bit indicates that a buffer has been received. It set after the last character is written to 
the receive buffer and the RX buffer descriptor is closed. 
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16.12.4.4 SP] MASK REGISTER. The 8-bit read/write SP! mask (SPIM) register has the 
same bit formats as the SPIE register. If a bit in the SPIM is 1, the corresponding interrupt 
in the SPIE register is enabled. If the bit is zero, the corresponding interrupt in the SPIE 
register is masked. This register is cleared by reset. 


SPIM 


(IMMR & OxFFFFO000) + OxAAA 


16.12.5 SPI Master Programming Example 


The following is an example initialization sequence for using the peripheral interface in 
master mode at a high speed. 


1. Configure the port B pins to enable the SPIMOSI, SPIMISO, and SPICLK pins. Write 
PBPAR and PBDIR bits 30, 29, and 28 with ones and then PBODR bits 30, 29, and 28 
with zeros. 


Note: For multimaster operation, enable the SPISEL pin to internally connect to the 
serial peripheral interface. 


2. Configure a parallel I/O pin to operate as the serial peripheral interface select pin if 
needed. If PB16 is chosen, write PBODR bit 16 with a zero, PBDIR bit 16 with a one, 
and PBPAR bit 16 with a zero. Then write PBDAT bit 16 with a zero to constantly 
assert the select pin. 


3. Write RBASE and TBASE in the SPI parameter RAM to point to the RX buffer 
descriptor and TX buffer descriptor in the dual-port RAM. Assuming one RX buffer 
descriptor at the beginning of the dual-port RAM and one TX buffer descriptor following 
that RX buffer descriptor, write RBASE with 0x2000 and TBASE with 0x2008. 


4. Program the CPM command register (CPCR) to execute the INIT RX AND TX 
PARAMS command. Write 0x0051 to the CPCR. | 


5. Write 0x0001 to the SDCR to initialize the SDMA configuration register. 
6. Write 0x18 to RFCR and TFCR for normal operation. 


7. Write MRBLR with the maximum number of bytes per receive buffer. For this case, 
assume 16 bytes, so MRBLR = 0x0010. 


8. Initialize the RX buffer descriptor and assume the RX data buffer is at Ox00001000 in 
main memory. Write OxBOO0 to RX_BD_Status, 0x0000 to RX_BD_Length (optional), 
and 0x00001000 to RX_BD_Pointer. 
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9. Initialize the TX buffer descriptor and assume the TX data buffer is at OxO00002000 in 
main memory and contains five 8-bit characters. Write 0xB800 to TX_BD _Status, 
0x0005 to TX_BD_Length, and 0x00002000 to TX_BD_Pointer. 

10.Write OxFF to the SPIE register to clear any previous events. 


11.Write 0x37 to the SPIM register to enable all possible serial ponpaer interface . 
Pica 


“system interrupt. The CICR should also be initialized. 


13.Write 0x0370 to the SPMODE register to enable normal operation (not baciatic. 
master mode, serial peripheral interface enabled, 8-bit characters, and the fastest 
speed possible. 


14.Set the STR bit in the SPCOM register to start the transfer. 


Note: After 5 bytes are transmitted, the TX buffer descriptor is closed. Additionally, the 
receive buffer is closed after 5 bytes are received because the L bit of the TX 
buffer descriptor is set. 





16.12.6 SPI Slave Programming Example 


The following is an example initialization sequence to follow when the serial peripheral 
interface is in slave mode. It is very similar to the serial peripheral interface master example, 
except that the SPISEL pin.is used instead of a general-purpose |/O pin. 





1. Configure the port B pins to enable the SPIMOSI, SPIMISO, SPISEL, and SPICLK 

pins. Write PBPAR bits 31, 30, 29, and 28 with ones and the PBODR bits 31, 30, 29, 
- and 28 with zeros. Write PBDIR bits 30, 29, and 28 with ones and bit 31 with zero. 
2. Write RBASE and TBASE in the SPI parameter RAM to point to the RX buffer 

~- descriptor and TX buffer descriptor in the dual-port RAM. Assuming one RX buffer 
descriptor at the beginning of the dual-port RAM and one TX buffer descriptor following 
that RX buffer descriptor, write RBASE with Ox2000 and TBASE with 0x2008. 

3. Write 0x18 to RFCR and TFCR for normal operation. | 


4. Program the CPM command register (CPCR) to execute the INIT RX AND TX 
PARAMS command. Write 0x0051 to the CPCR. 


5. Write 0x0001 to the SDCR to initialize the SDMA configuration register. 
6. Write MRBLR with the maximum number of bytes per receive buffer. Assume 16 
bytes, so MRBLR = 0x0010. 


7. Initialize the RX buffer descriptor and assume the RX data buffer is at 0x00001000 in 
~ main memory. Write OxBO00 to RX_BD_Status, 0x0000 to RX_BD _tength sCplonet) 
and 0x00001000 to RX_BD_Pointer. 


8. Initialize the TX buffer descriptor and assume the TX data buffer is at Ox00002000 in 
~ main memory and contains five 8-bit characters. Write OxB800 to TX_BD- Status, 
0x0005 to TX_BD_Length, and 0x00002000 to TX_BD_Pointer. 
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9. Write OxFF to the SPIE register to clear any previous events. 


10. Write 0x37 to the SPIM register to enable all possible serial peripheral interface 
interrupts. 


11.Write 0x00000020 to the CIMR to allow the serial peripheral interface to generate a 
system interrupt. The CICR should also be initialized. 


12.Write 0x0170 to the SPMODE register to enable normal operation (not loopback), 
master mode, serial peripheral interface enabled, and 8-bit characters. The SPI baud 
rate generator speed is ignored because the serial peripheral interface is in slave 
mode. 


13. Set the STR bit in the SPCOM register to enable the serial peripheral interface to be 
ready once the master begins the transfer. 


| iw Note: If the master transmits 3 bytes and negates the SPISEL pin, the RX buffer 
| descriptor is closed but the TX buffer descriptor remains open. If the master 
transmits 5 or more bytes, the TX buffer descriptor is closed after the fifth byte. 
lf the master transmits 16 bytes and negates the SPISEL pin, the RX buffer 
descriptor is closed with no errors and no out-of-buffers error occurs. If the 
master transmits more than 16 bytes, the RX buffer descriptor is closed 
(completely full) and the out-of-buffers error occurs after the 17th byte is 
received. 





16.12.7 Handling Interrupts in the SPI 


The following sequence should be followed to handle interrupts in the serial peripheral 
interface. 7 


1. Once an interrupt occurs, read the SPIE register to find out what caused the interrupts. 
Normally, the SPIE bits should be cleared at this time. 


2. Process the TX buffer descriptor to reuse it and the RX buffer descriptor to extract the 
data from it. To transmit another buffer, simply set the TX buffer descriptor R bit, RX 
buffer descriptor E bit, and STR bit in the SPCOM register. 


3. Clear the SPI bit in the CISR. 
4. Execute the rfi instruction. 
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16.13 THE I?C CONTROLLER 


The inter-integrated circuits (I2?C®) controller enables the MPC823 to exchange data with a 
number of other I?C devices, such as microcontrollers, EEPROMs, real-time clock devices, 
A/D converters, and LCD displays. The I?C controller is a synchronous, multimaster bus that 
is used to connect several integrated circuits on a board. It uses two wires—serial data 
(SDA) and serial clock (SCL)—to carry information between the integrated circuits that are 
connected to it. 


The I?C controller consists of transmitter and receiver sections, an independent baud rate 
generator, and a control unit. The transmitter and receiver sections use the same clock, 
which is derived from the I?C baud rate generator in master mode and generated externally 
in slave mode. According to the I*C specification, wait states are inserted during a data 
transfer if the SCL signal is held low by a slave device. As a master in the middle of a data 
transfer, the I*C controller recognizes wait states by monitoring the SCL signal. The I?C 
controller does not begin counting down from a specific timeout value when SCL is asserted, 
so the software should monitor SCL assertion times for bus timeout. 


PERIPHERAL BUS ___U-BUS 


RX DATA REGISTER TX DATA REGISTER MODE REGISTER 
SHIFT REGISTER SHIFT REGISTER 
















SDA 


CONTROL 


Poa 
ee 


BRG SCL 





Figure 16-124. IC Controller Block Diagram 


The I°C receiver and transmitter are double-buffered, which corresponds to an effective 
FIFO size of 2 characters. The MPC823 I7C bit 0 (MSB) is shifted out first. When the I?C is 
not enabled in the I2MOD register, it consumes very little power. 


16-446 MPC823 USER’S MANUAL MOTOROLA 


Communication Processor Module 
16.13.1 Features 
The following is a list of the IC controller's main features: 


¢ Two-Pin Interface 
e Full-Duplex Operation 


Master or Slave I2C Mode Support 


MultiMaster Environment Support 


Continuous Transfer Mode for Autoscanning of a Peripheral 
¢ Supports Maximum Capacitive Load of 400pF on Both Bus Lines (Fully 1? Compliant) 
e Independent Programmable Baud Rate Generator 


Supports |?C Low and High Speed Operation 
Supports 7-Bit I?C Addressing 
e Open-Drain Output Pins Support MultiMaster Configuration 


e Local Loopback Capability for Testing 


16.13.2 IC Controller Clocking and Pin Functions 


Both the serial data (SDA) and serial clock (SCL) are bidirectional pins that need to be 
connected to a positive 5V power supply via an external pull-up resistor in the 6.8K Ohm to 
10K Ohm range. Both pins are high when the I@C bus is free. The SCL signal clocks in 
received data and clocks out transmitted data on the SDA pin. 


The I?C controller can be configured as a master or slave. When configured as a master, the 
l?C controller generates SCL, and then initiates and terminates the I/O operation. In addition, 
the IC controller generates the SCL signal via a dedicated baud rate generator that takes 
its input from BRGCLK, which is described in Section 5.3.4.2 The Baud Rate Generator 
Clock. When configured as a slave, the |?C controller receives SCL as an input. 


An I°C transaction is initiated when the master generates a start condition, which is defined 
as the SDA signal making a high-to-low transition while SCL is high. An acknowledge (ACK) 
is generated by the I?C receiver after each byte transfer. The receiver signals an ACK by 
driving the SDA signal low during the SCL clock pulse immediately following each data byte 
transmission. The data and ACK signals are always sampled on the rising edge of SCL. If 
the receiver does not issue an ACK after a data byte is transmitted, the I?C master generates 
a stop condition and transmission stops. A stop condition is when the SDA signal makes a 
low to high transition while the SCL signal remains high, as illustrated in Figure 16-125. 
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Figure 16-125. I?C Timing 


16.13.3 I?C Controller Transmission and Reception Process 
16.13.3.1 I2¢ MASTER MODE. The [2C controller, when functioning in master mode, 


initiates a transaction by transmitting a message specifying a read or write operation to the 


I?C slave. If a read operation is specified, the direction of the transfer is changed after the 
read operation is acknowledged, and the slave device then becomes the transmitter. If a 
write operation is specified, the direction of the transfer remains unchanged. | 


As the l?C controller shifts out each bit, it monitors the level of the SDA pin to detect a 


possible collision with other I?C master transmitters. If a collision is detected, transmission 


stops and the controller reverts to slave mode. A maskable interrupt may be issued to the 
core to allow the software to retransmit later. | | 


In master mode operation, setting the S bit i the TX buffer descriptor control and status field 
will cause a start condition to be sent before this buffer is transmitted. If the TX buffer 
descriptor is the first one in the ring, then a start condition will be issued regardless of the S 


bit setting. Setting the L bit will cause a stop condition to be sent after the buffer is 


transmitted. You must set the L bit for the last TX buffer in the ring. 


You must the set M/S bit in the I2COM register to configure the controller as a master. Clear 
the IZCMOD register’s EN bit to disable the I?C controller before programming the SCL clock 
frequency you want with the I2MOD and I2BRG registers. The l2ADD register does not need 
to be programmed when you are operating the |?C controller in single-master mode. Enable 
the I?C controller by setting the EN bit in me I2MOD register. 
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16.13.3.1.1 Master Write. To begin a write operation to a slave device that contains 
internal addresses, you need to prepare a TX data buffer that is N+2 bytes in length. The 
first byte contains the 7-bit device address, followed by the write bit asserted (R/W = 0). The 
second byte contains the internal base address of the write. The remaining N bytes contain 
the data to be written to the slave. The slave device will process the N bytes of data 
sequentially, starting at the specified base address. 


4ADYrian 
VTOAM 


A A A 
C C C 
K K K 


ave DEVICEADDR |W BASE ADDR DATA BYTE 


NOTE: DATA AND ACK ARE REPEATED N TIMES. 
Figure 16-126. Byte Write to Device with Internal Addresses 


To begin a master write operation to a slave device that does not contain internal addresses, 
you need to prepare a TX data buffer that is N+1 bytes in length. The first byte contains the 
7-bit slave device address, followed by the write bit asserted (R/W = 0). The remaining N 
bytes contain the data to be written to the slave. 


o4aDvYr-inm 
VOIdIM 


AOS 


C 
SDA DEVICEADDR |W|K[ DATABYTE 
NOTE: DATA AND ACK ARE REPEATED N TIMES. 
Figure 16-127. Byte Write to Device without Internal Addresses 


Next, when communicating to either slave device, the TX buffer descriptor’s control and 
status field must have the W and L bits set. Set the | bit in the TX buffer descriptor to enable 
the transmission status to be updated in the I2CE register, and to enable I@C interrupts to 
the core. Set the R-bit in the TX buffer descriptor to prepare the buffer for transmission. The 
final step is to set the STR bit in the I2COM register to initiate transmission. The data starts 
transmitting once the SDMA channel loads the transmit FIFO with data and the I?C bus is 
not busy. 


Note: Some slave devices such as serial E2PROMs may have a minimum write cycle 
time. For these devices, the I?C controller must wait a specified minimum time 
after a write before initiating a subsequent read or write. The needed delay must 
be implemented in software. 
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16.13.3.1.2 Master Read. To begin a read operation to a slave device that contains internal 


ameace S addresses, you need to prepare two TX buffer descriptors. TX buffer descriptor 0 should be 
*® \ 2 bytes in length. TX buffer descriptor 1 should be N+1 bytes in length, where Nis the | 
ee number of bytes to be read sequentially from the slave device. You also need to prepare one 





or more receive buffers for the N bytes of data to receive from the slave device. 


The first byte of TX buffer descriptor 0 should contain the 7-bit slave address followed by the 
write bit asserted (R/W = 0). The second byie of the first transmit buffer should coniain the 
1-byte internal address on the slave device. This is the base address on the slave device of 
the data to be read. The transmission of TX buffer descriptor 0 is commonly referred to as 


a dummy write. Its purpose is to select the slave device. 


The first byte of the second TX buffer descriptor (1) should contain the slave address 
followed by the read bit asserted (R/W = 1). The remaining N bytes of TX buffer descriptor 
1 may be uninitialized and merely serve as a place holder for the |2C controller. The TX 
buffer descriptor 1 control and status field should have the W, L, and S bits set. 


4ADYroim 
AOYF O24 
vOoOHmM 


| AHpriM 


A A A 
SDA C C C 
[| DEVICEADDR |W| K[__ BASE ADDR K DEVICE ADDR |RIK DATABYTE 


NOTE: DATA AND ACK ARE REPEATED N TIMES. 
Figure 16-128. Byte Read from Device with Internal Addresses 


To begin a read operation to a slave device that does not contain internal addresses, you 
need to prepare TX buffer descriptor N+1 bytes in length, where N is.the number of bytes to 
be read sequentially from the slave device. The first byte of the TX buffer descriptor should 
contain the 7-bit slave address followed by the read bit asserted (R/W = 1). You also need 
to prepare one or more receive buffers for the N bytes of data to receive from the slave 
device. | | | 
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NOTE: DATA AND ACK ARE REPEATED N TIMES. 
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Figure 16-129. Byte Read from Device without Internal Addresses 
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When communicating to either slave device, set the R bit in the TX buffer descriptor(s) to 
prepare them for transmission. Set the | bit in the TX and RX buffer descriptors to enable 
the transmission and reception status to be updated in the I2CE register, and to enable |?C 
interrupts to the core. Set the E bit on the RX buffer descriptor(s) to prepare them for 
reception. Finally, set the STR bit in the l2COM register to initiate transmission. The data 
starts transmitting once the SDMA channel loads the transmit FIFO with data and the I@C 
bus is not busy. 


16.13.3.1.3 I?C Loopback Configuration. Loopback on the I?C controller is a special case 
of master mode operation with a device that does not contain internal addresses. Refer to 
Figure 16-127 and Figure 16-129 for more information. To begin a loopback transmission, 
you need to prepare a TX buffer descriptor with a data buffer N+1 bytes in length, where N 
is the number of data bytes to be written back to the I?C controller. You also need to prepare 
one or more RX buffer descriptors to receive back the N bytes of data. 


The first byte of the TX buffer descriptor should contain the address of the MPC823 I?C 
device’s own address, as contained in the I2CADD register, followed by the write bit 
asserted (R/W = 0). The remaining N bytes of the TX buffer descriptor contain the data to 
be sent and received by the I°C controller. 


Next, set the R bits on the TX buffer descriptor and the E bits in the RX buffer descriptors. 
The TX buffer descriptor control and status field should have the W and L bits set. The 
setting of the L bit will cause a stop condition to be issued after this buffer is transmitted to 
conclude the operation. Set the | bit in the TX and RX buffer descriptors to enable the 
transmission and reception status to be updated in the I2CE register, and to enable |@C 
transmit and receive interrupts to the core. You should then set the STR bit in the IZCOM 
register to initiate the loopback operation. : 


16.13.3.2 I2?C SLAVE MODE. When the I?C controller functions in slave mode, it receives 
messages from an |?C master and, in turn, sends back a reply. Once the I?C controller is 
configured for slave mode operation by clearing the M/S bit in the l2COM register, the SCL 
signal becomes an input driven by the external master. The IC controller can operate with 
an SCL of any frequency from DC to beyond 400kHz. 


After the start condition, the first transmitted byte to the I?C slave device contains the 7-bit 
slave device address and the read/write bit. The I?C controller will compare the transmitted 
slave device address with its own programmed address. If there is a match, the read/write 
bit is evaluated. 


You must the clear the M/S bit in the l2COM register to configure the controller as a slave. 
You do not program the I2MOD and I2BRG registers to set the SCL frequency, as SCL is 
an input to the slave. Program the I2ADD register with the 7-bit I@C address of the slave. 
Enable the I@C controller by setting the EN bit in the I2MOD register. 
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16.13.3.2.1. Write to Master. If a write operation is requested by an external master, the 
I2?C controller acknowledges the received data and writes it into a receive buffer using the 


next available RX buffer descriptor until the next start or stop condition is detected. 


After transmitting each data byte, the master checks for the acknowledge bit from the slave. 
If an overrun condition occurs on the slave receiver, it will fail to acknowledge a byte and the 
transmission will abort. An overrun condition occurs when more data is transmitted than the 
slave can receive. A maskable interrupt may be issued by the |?C controller at the conciusion 
of a normal or errant reception. 


To prepare the I?C controller in slave mode for data reception, you must configure one or 
more RX buffer descriptors to receive the data from the master. Set the E bit in the RX buffer 
descriptors to prepare them to receive data. Other RX buffer descriptor control bits, such as 
W and I, may be set as appropriate. You should then set the STR bit in the I2COM register 
to prepare the slave to respond to the master. 


16.13.3.2.2 Read from Master. If a read operation is requested by an external master, the 
°C controller will acknowledge the newly received byte containing the slave address and 
read bit (R/W = 1), only if the transmitter FIFO has been loaded by the SDMA channel. 


If the transmitter is ready, the slave starts transmitting on the next clock pulse following the 
acknowledge. Otherwise, the transaction is aborted and a maskable TX error interrupt may 


_be issued to notify the software to prepare data for transmission on another attempt. A 


maskable interrupt may be issued upon normal completion of transmission or after a other 
transmission.errors occur. If an underrun condition occurs, the slave transmits ones until a 
stop condition is detected. An underrun occurs if the slave device does not transmit all of the 
data requested by the master. 


To prepare the I?C controller in slave mode for data transmission, you must configure one 
or more TX buffer descriptors to transmit the data to the master. Set the E bit in the RX buffer 
descriptors to prepare them to receive data. Other TX buffer descriptor control bits, such as 
W, !, and L, may be set as appropriate. You should then set the STR bit in the l2COM. 
register to prepare the slave to respond to the master. 
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16.13.4 ?C Parameter RAM Memory Map 


The I?C controller parameter RAM area begins at the IC base address, which is used for 
the general IC parameters. It is similar to the SCC2 general-purpose parameter RAM. You 


must initialize certain parameter RAM values before the serial peripheral interface is 


enabled. The communication processor module initializes the other values. Once initialized, 
the parameter RAM values do not usually need to be accessed by your software. They 
should only be modified when there is no serial peripheral interface activity in progress. 


Table 16-40. I?C Controller Parameter RAM Memory Map 



















NOTE: You are only responsible for initializing the items in bold. I°C Base = (IMMR & OxFFFFO000) + 0x3C80. 


[nooness [wane [worm [_oesowrow 















e RBASE and TBASE—The RX and TX buffer descriptor base address entries are where 
the dual-port RAM starts receiving and transmitting data for the IC buffer descriptors. 
They provide a great deal of flexibility in how buffer descriptors for an I?C controller are 
partitioned. By selecting RBASE and TBASE entries for the I@C controller and by setting 
the W bit in the last buffer descriptor in each buffer descriptor list, you can select how 
many buffer descriptors to allocate for the transmit and receive side of the I@C controller. 
However, you must initialize these entries before enabling the corresponding channel. 
Furthermore, you should not configure the buffer descriptor tables of the I¢C controller 
to overlap because erratic operation will occur. RBASE and TBASE should contain a 


value that is divisible by eight. 
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e RFCR and TFCR—The RX and TX function code entries contain the value that you 


———_ want to appear on the AT pins when the associated SDMA channel accesses memory. 
3 he ; _ This register controls the byte-ordering convention used in the transfers. 
eee | oe : 

RFCR 





12C BASE + 0x04 


Bits O-2—Reserved 
These bits are reserved and should be set to 0. 


BO—Byte Ordering 
You should set these bits to select the sealed byte ordering of the data buffer. 


00 = 


01 


1X 


The DEC/Intel convention is used for byte ordering (swapped operation) and 
is also called little-endian byte ordering. The transmission order of bytes within 
a buffer word is reversed in comparison to the Motorola mode. This mode is 
supported only for 32-bit port size memory. 

PowerPC little-endian byte ordering. As data is transmitted onto the serial line 
from the data buffer, the least-significant byte of the buffer double-word 
contains data to be transmitted earlier than the most-significant byte of the 
same buffer double-word. 

Motorola byte ordering (normal operation) is also called big-endian byte 
ordering. As data is transmitted onto the serial line from the data buffer, the 
most-significant byte of the buffer word contains data to be transmitted earlier 
than the least-significant byte of the same buffer word. 


AT—Address Type 1-3 


These bits contain the function code value used Auting the SDMA channel memory 
access. ATO is driven with a { to identify this SDMA channel access as a DMA-type 


access. 
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Bits O-2—-Reserved 
These bits are reserved and should be set to 0. | ss 


BO—Byte Ordering <a 
You should set this bit to select the required byte ordering of the data buffer. 


00 = The DEC/Intel convention is used for byte ordering (swapped operation) and 
is also called little-endian byte ordering. The transmission order of bytes within 
a buffer word is reversed in comparison to the Motorola mode. This mode is 
supported only for 32-bit port size memory. 

01 = PowerPC little-endian byte ordering. As data is transmitted onto the serial line 
from the data buffer, the least-significant byte of the buffer double-word 
contains data to be transmitted earlier than the most-significant byte of the 
same buffer double-word. 

1X = Motorola byte ordering (normal operation) is also called big-endian byte 
ordering. As data is transmitted onto the serial line from the data buffer, the 
most-significant byte of the buffer word contains data to be transmitted earlier 
than the least-significant byte of the same buffer word. 


AT—Address Type 1-3 


These bits contain the function code value used during the SDMA channel memory 
access. ATO is driven with a 1 to identify this SDMA channel access as a DMA-type 
access. | 


MRBLR—The I7C controller has a maximum receive buffer length register entry to 
define its receive buffer length and it defines the maximum number of bytes that the 
MPC823 writes to a receive buffer on that I?C controller before moving to the next 
buffer. The MPC823 writes fewer bytes to the buffer than the MRBLR value if an error 
or end-of-frame occurs, but it never writes more bytes than the MRBLR value. Buffers 
you supply for the MPC823 to use should always be at least as long as MRBLR. The 
I?C transmit buffers are not affected by the value you program into MRBLR and they 
can be individually chosen to have varying lengths, as needed. You choose the number 
of bytes to be transmitted by programming the DATA LENGTH field in the TX buffer 
descriptor. 


MRBLAR is not intended to be dynamically changed while an |?C controller is operating. 
However, if it is modified in a single bus cycle with one 16-bit move (not two 8-bit bus 
cycles back-to-back), a dynamic change in receive buffer length can be successfully 
achieved. This occurs when the communication processor module moves control to the | 
next RX buffer descriptor in the table. Thus, a change to MRBLR does not have an | 
immediate effect. To guarantee the exact RX buffer descriptor on which the change 
occurs, you should only change MRBLR when the I7C receiver is disabled. The MRBLR 
value should be greater than zero and should be even if the character length of the data 
is greater than eight bits. | | 
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¢ RBPTR—The receive buffer pointer entry for each I?C channel points to the next buffer 
descriptor that the receiver transfers data to when it is in an idle state or to the current 
& buffer descriptor during frame processing. After a reset or when the end of the buffer 
| descriptor table is reached, the communication processor module initializes this pointer 
to the value programmed in the RBASE entry. Although in most applications you should 
not write the RBPTR, it can be modified when the receiver is disabled or when you are 
sure no receive buffer is currently in use. 


¢ TBPTR—The transmit buffer pointer entry for each I?C channel points to the next buffer 
descriptor that the transmitter transfers data from when it is in an idle state or to the 
current buffer descriptor during frame transmission. After a reset or when the end of 
buffer descriptor table is reached, the communication processor module initializes this 
pointer to the value programmed in the TBASE entry. Although in most applications you 
should not write TBPTR, it can be modified when the transmitter is disabled or when 
you are sure no transmit buffer is currently in use. 


¢ Other General Parameters—For normal operation, you do not need to access these 
parameters. They are only listed here because they provide helpful information for 
experienced users and they can be used for debugging purposes. Additional 
parameters are listed in Table 16-40. RPTR and TPTR are updated by the SDMA 
channels to show the next address to be accessed. TCNT is a down-count value that 
is initialized with the TX buffer descriptor data length and decremented with every byte 
read by the SDMA channels. RCNT is a down-count value that is initialized with the 
MRBLR value and decremented with every byte the SDMA channels write. The 
RSTATE, TSTATE, RTMP, TTMP, and reserved areas can only be used by the RISC 
microcontroller. 


16.13.5 I2?C Commands 


You can program the CPM command register (CPCR) with the following commands to 
transmit or receive data. 


© INIT TX PARAMETERS—This command initializes all transmit parameters in this serial 
channel's parameter RAM to their reset state and should only be issued when the 
transmitter is disabled. The INIT TX AND RX PARAMS command can also be used to 
reset the transmit and receive parameters. 


¢ CLOSE RX BD—This command is used to force the I?C controller to close the current 
RX buffer descriptor if it is being used and to use the next buffer descriptor for any 
subsequently received data. If the IC controller is not in the process of receiving data, 
no action is taken by this command. 

INIT RX PARAMETERS—This command initializes all the receive parameters in this 
serial channel’s parameter RAM to their reset state and should only be issued when the 


receiver is disabled. The INIT TX AND RX PARAMS command can also be used to 
reset the receive and transmit parameters. 
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16.13.6 The I?C Buffer Descriptor Ring 


The data associated with the I?C controller is stored in buffers, which are referenced by 
buffer descriptors organized in a buffer descriptor ring located in the dual-port RAM. This 
ring has the same basic configuration as the serial communication and serial management 
controllers. 


The buffer descriptor ring forms a circular queue that helps you arrange the buffers you want 
to transmit or receive. Using the buffer descriptors, the communication processor module 
confirms reception and transmission or indicates error conditions so that the processor 
knows the buffers have been serviced. The actual buffers can reside in either external 
memory or internal memory and the data buffers can reside in the parameter RAM area of 
another controller if it is not enabled. 


DUAL-PORT RAM EXTERNAL MEMORY 
—— a 
a ones 
POINTER TO l2C 
TX RING 
: RX DATA BUFFER 
DATA LENGTH 


RX RING 
Figure 16-130. I?C Memory Format 
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FRAME STATUS 
DATA LENGTH 
DATA POINTER 
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| FRAME STATUS 
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16.13.7 Programming the I?C Controller 


16.13.7.1 fC MODE REGISTER. The read/write I°C mode (I2MOD) register controls both 
the I?C operation mode and clock source. 





I2MOD 


(IMMR & OxFFFFOO00) +0x860 





Bits O—1—Reserved 
These bits are reserved and should be set to 0. 


REVD—Reverse Data 
This bit determines the receive and transmit character bit order. 


O= Normal operation. Most-significant bit of character transmitted and received first. 
1= Reverse data. Least-significant bit of character transmitted and received first. 


GCD—General Call Disable 
This bit determines if the receiver will acknowledge a general call address. 


O= General call address is enabled. 
1= General call address is disabled. 


FLT—Clock Filter 
This bit determines if the I?C input clock is filtered to prevent spikes in a noisy environment. 


0 = I2CLK is not filtered. 
1 = I2CLK is filtered by a digital filter. 


PDIV—Pre Divider 


This field determines the division factor of the clock before it is fed into the baud rate 
generator. The clock source for the I?C controller is the BRGCLK that is generated by the 
system interface unit. 


@ 


00= Use the BRGCLK/22 as the input to the I@C baud rate generator. 
01= Use the BRGCLK/16 as the input to the I@C baud rate generator. 
10= Use the BRGCLK/8 as the input to the I?C baud rate generator. 
11= Use the BRGCLK/4 as the input to the I°C baud rate generator. 
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EN—Enable |?C 


This bit enables |?C operation. When EN is cleared, the |?C controller is in a reset state and 
consumes minimal power. | 





O= |*C controller is disabled. 
1 = |2C controller is enabled. 


Note: Do not modify other bits of the I2MOD register when the EN bit is set or else 
erratic operation will occur. 


16.13.7.2 I?C RECEIVE BUFFER DESCRIPTOR. Using receive (RX) buffer descriptors, 
the communication processor module reports information about each buffer of received | 
data, closes the current buffer, generates a maskable interrupt, and starts receiving data in 
the next buffer when the current buffer is full. In addition, it closes the buffer when a stop or 
start condition is found on the I@C bus or when an overrun error occurs. 


The first word of the RX buffer descriptor contains status and control bits, which you prepare 
before reception and then the communication processor module sets them after the buffer 
is closed. The second word contains the data length (in bytes) that is received and the third 
and fourth words contain a pointer that always points to the beginning of the received data 
buffer. The core should write these RX buffer descriptor bits before the IC controller is. 
enabled. | 


Note: The communication processor module sets all the status bits in this buffer 
descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error: 
bit is only set when a parity error occurs. 





pejrs|wir ie] resemen | ov [nes 


RX DATA BUFFER POINTER 





NOTE: You are only responsible for initializing the items in bold. 
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E—Empty 

0 = The data buffer associated with this RX buffer descriptor is filled with received data 
or data reception is aborted due to an error condition. The core is free to examine 
or write to any fields of this RX buffer descriptor. The communication processor 
module does not use this buffer descriptor as long as the E bit is zero. 

1 = The data buffer associated with this buffer descriptor is empty or reception is 
currently in progress. This RX buffer descriptor and its associated receive buffer 
are owned by the communication processor module. Once the E bit is set, the core 
should not write any fields of this RX buffer descriptor. 


Bits 1, 5-13, and 15—Reserved 
These bits are reserved and should be set to 0. 


W—Wrap (Final Buffer Descriptor in Table) 


0 = This is not the last buffer descriptor in the RX buffer descriptor table. 

1 = This is the last buffer descriptor in the RX buffer descriptor table. After this buffer 
is used, the communication processor module receives incoming data into the first 
buffer descriptor that RBASE points to in the table. The number of RX buffer 
descriptors in this table is programmable and determined only by the W bit and 
overall space constraints of the dual-port RAM. 


I—Interrupt ; 
0 = No interrupt is generated after this buffer is filled. 
1= The RXB bit in the I2CE register is set when this buffer is completely filled by the 
communication processor module, indicating the need for the core to process the 
buffer. The RXB bit can cause an interrupt if it is enabled. 


L—Last | 

The I2C controller sets this bit when the buffer is closed because a stop (or start) condition 
occurred on the bus or as a result of an overrun. The I?C controller writes this bit after the 
received data is placed into the associated data buffer. 


0 = This buffer does not contain the last character of the message. 
1= This buffer contains the last character of the message. 


OV—Overrun 


This bit indicates that a receiver overrun has occurred during reception. The I?C controller 
_ writes this bit after the received data is placed into the associated data buffer. 
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DATA LENGTH 


This field represents the number of octets that the communication processor module writes 
into this buffer descriptor data buffer. The communication processor module writes it once 
the buffer descriptor closes. The I*C controller writes these bits after the received data is 
placed into the associated data buffer. The actual amount of memory allocated for this buffer 
should be greater than or equal to the MRBLR. 


RX DATA BUFFER POINTER 


This field always points to the first location of the associated data buffer, must be even, and 
can reside in internal or external memory. The |?C controller writes these bits after the 
received data is placed into the associated data buffer. 


16.13.7.3 I? TRANSMIT BUFFER DESCRIPTOR. Data to be transmitted with the |@C is 
sent to the communication processor module by arranging it in buffers referenced by the 
transmit (TX) buffer descriptor ring. The first word of the TX buffer descriptor contains status 
and control bits. You should prepare the following bits before transmitting data. 


putes | reseaveo [nak] ww | oo 


ra jes] w 


TX DATA BUFFER POINTER 





e 
NOTE: You are only responsible for initializing the items in bold. 


Note: The communication processor module sets all the status bits in this buffer 
descriptor. You should clear all the status bits before submitting the buffer 
descriptor to the communication processor module. For example, the parity error 
bit is only set when a parity error occurs. 





R—Ready 

O= The data buffer associated with this buffer descriptor is not ready for transmission. 
You are free to manipulate this buffer descriptor or its associated data buffer. The 
communication processor module clears this bit after the buffer is transmitted or 
after an error occurs. | 

1 = The data buffer, which you prepare for transmission, is not transmitted yet or is 
currently being transmitted. You cannot write any fields of this buffer descriptor 
once this bit is set. 


Bits 1 and 6—12—Reserved 
These bits are reserved and should be set to 0. 
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Communication Processor Module 


W—Wrap (Final Buffer Descriptor in Table) 
O= This is not the last buffer descriptor in the TX buffer descriptor table. 
1= This is the last buffer descriptor in the TX buffer descriptor table. After this buffer is 
used, the communication processor module receives incoming data into the first 
buffer descriptor that TBASE points to in the table. The number of TX buffer 
descriptors in this table is programmable and determined only by the W bit and 
overall space constraints of the dual-port RAM. 


I—Interrupt 


O= No interrupt is generated after this buffer is serviced. 
1= The TXB or TXE bit in the event register is set when this buffer is serviced. TXB 
and TXE can cause interrupts if they are enabled. 


|[—Last 


O= This buffer does not contain the last character of the message. 
1= This buffer contains the last character of the message. 


S—Transmit Start Condition | 

When this bit is set to 1, the IC controller transmits a start condition before the first byte of 
the buffer. If this buffer descriptor is the first one in the frame, a start condition is transmitted 
regardless of the value of this bit. This bit provides the ability to transmit a start byte or 


_ back-to-back frames. 


O= Astart condition is not transmitted before the first byte of the buffer, unless it is the 
first byte of a frame. | | 
1= A start condition is transmitted before the first byte of the buffer. 


NAK—No Acknowledge 


This bit indicates that the transmission has been aborted because the last transmitted byte 
was not acknowledged. The I?C controller writes this bit after it finishes transmitting the 
associated data buffer. | 


UN—Underrun 


This bit indicates that the I?C controller has encountered a transmitter underrun condition 
while transmitting the associated data buffer. The I?C controller writes this bit after it finishes 
transmitting the associated data buffer. | 


CL—Collision 


This bit indicates that transmission has been aborted because the transmitter was lost while 
arbitrating for the bus. The I?C controller writes this bit after it finishes transmitting the 
associated data buffer. 
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DATA LENGTH 


This field represents the number of octets the communication processor module should as 
transmit from this buffer descriptor data buffer. However, it is never modified by the ae 
communication processor module. Normally, this value should be greater than zero. The I2C 
controller writes these bits after it finishes transmitting the associated data buffer. 


TX DATA BUFFER POINTER 


This field always points to the first location of the associated data buffer. They can be even 
or odd, unless the number of actual data bits in the character is greater than 8 bits, in which 
case the transmit buffer pointer must be even. The buffer can reside in internal or external 
memory. The I*C controller writes these bits after it finishes transmitting the associated data 
buffer. 


16.13.7.4 I?C ADDRESS REGISTER. The 8-bit, memory-mapped, read/write I?C address 
(I2ADD) register holds the address for this I@C port. You need to program this register if you 
are operating in multimaster, slave, or local loopback mode. 












I2ADD 





| (IMMR & OxFFFFO000) + OxA64 | 


SAD— Slave Address 0-6 
This field holds the slave address for the I2C port. 





Bit 7—Reserved 
This bit is reserved and should be set to 0. 


PROCESSOR MODULE | 
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Communication Processor Module 





16.13.7.5 I? BAUD RATE GENERATOR REGISTER. The 8-bit, memory mapped, | 
read/write I@C baud rate generator (I2BRG) register sets the divide ratio of the baud rate 
generator. This register is set to all ones at hard reset. 


I2BRG 


(IMMR & OxFFFFO000) + 0x868 





DIV— Division Ratio 0—7 


This field specifies the divide ratio of the baud rate generator divider in the IC clock 
generator. The output of the prescaler is divided by 2 x (DIV + 3 + (2 x FLT)) and the clock 
has a 50% duty cycle. The FLT bit is in the I2MOD register. 


Note: The minimum value for DIV is three if the digital filter is enabled and six of it is 
enabled. 





16.13.7.6 12?¢ COMMAND REGISTER. The 8-bit read/write I7C command (l2COM) register 
is used to start I?C operation. 


I2COM 


. ‘ a, 
ee ee es 2 es ees ee 


STR RESERVE 


z 


(IMMR & OxFFFF0000) + 0x86C 





STR—Start Transmit 


When the I7C controller is in master mode, setting this bit to 1 causes the I?C controller to 
start transmitting data from the I?C transmit buffers if they are ready. When the I°C controller 
is in slave mode, setting the STR bit to 1 when the I?C controller is idle causes it to load the 
transmit data register from the I*C transmit buffer and start transmitting when it receives an 
address byte that matches the slave address with the R/W bit set to 1. The STR bit is always 
read as a zero. 
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Bits 1-6—Reserved. 
These bits are reserved and should be set to 0. 





M/S—Master/Slave 
This bit configures the I*C controller to operate as a master or a slave. 


O= |*C controller is a slave. 
1 = l*C controller is a master. 


16.13.7.7 ?}C EVENT REGISTER. The 8-bit memory-mapped I@C event register (I2CER) is 
used to generate interrupts and report events recognized by the I?C controller. When an 
event is recognized, the IC controller sets its corresponding bit in the l2CER. Interrupts 
generated by this register can be masked in the I?C mask register. A bit is cleared by writing 
a 1 (writing a zero has no effect) and more than one bit can be cleared at a time. All 
unmasked bits must be cleared before the communication processor module clears the 
internal interrupt request. This register is cleared by reset and can be read at any time. 


I2CER 





(IMMR & OxFFFFO000) + 0x870 


Bits 0-2 and 4—Reserved 
These bits are reserved and should be set to 0. 


TXE—TX Error 
This bit indicates that an error has occurred during transmission. 


BSY—Busy Condition 


This bit indicates that received data has been discarded due to a lack of buffers. This bit is 
set after the first character is received for which there is no receive buffer available. 


TXB—TX Buffer | 


This bit indicates that a buffer has been transmitted. It is set once the transmit data of the 
last character in the buffer is written to the transmit FIFO. You must wait two character times 
to be sure that the data is completely sent over the transmit pin. 


RXB—RX Buffer 


This bit indicates that a buffer has been received. This bit is set after the last character is 
written to the receive buffer and the RX buffer descriptor is closed. 


COMMUNICATION 
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16.13.7.8 I7?C MASK REGISTER. The 8-bit read/write I?C mask register (I2CMR) has the 
same bit formats as the I2CER. If a bit in the I2CMR is 1, the corresponding interrupt in the 
I2CER is enabled. If the bit is zero, the corresponding interrupt in the IZCER is masked. This 
register is cleared by reset. 


I2CMR 


SI 









rr eee ee a ee 


| (IMMR & OxFFFFO000) + 0x874 


16.13.8 PC Controller Initialization Sequence 





The following initialization sequence is for the I?C controller to operate in master mode, and 
read one byte from a slave device that contains an internal read address. The I?C controller 
operates the SCL at 391kHz. A system frequency of 50MHz is assumed. The SDA and SCL 
pins of the MPC823 are connected to an external 5V power supply with 6.8K Ohm to 10K 
Ohm resistors. 


1. Configure the port B pins to enable the SDA and SCL pins. Write PBPAR, PBDIR, and 
_PBODR bits 26 and 27 with ones. 


2. Disable the I*C controller by clearing the 12MOD register, including the EN bit. Now 
you can modify other fields in the I2MOD register. 


3. Configure the I*@C dedicated baud rate generator to operate at 391kHz at a system 
frequency of 50MHz by programming the divider and pre-divider. The overall IC baud 
rate generator clock divider is 128 (decimal), and is realized by establishing a 
pre-divider of 8 and a divider of 16. Write the PDIV field of the l2MOD register with 2 
to pre-divide by 8. Write the DIV field of the I2BRG register with 5 to divide by 16. 


4. Write 0x01 to the I2COM register to configure controller for master mode operation. 
©. Write 0x0001 to the SDCR to set the SDMA bus arbitration level to 5. 


6. Write RBASE and TBASE in the I?C parameter RAM to point to the RX and TX buffer 
descriptors in the dual-port RAM. Assuming the initial RX buffer descriptor at the 
beginning of dual-port RAM and the initial TX buffer descriptor 64 bytes from the 

beginning, write RBASE with 0x2000 and TBASE with 0x2040. 


7. Write 0x11 into the CPCR to execute the INIT RX AND TX PARAMS command for I°C. 
8. Write 0x15 into the RFCR and TFCR for normal operation. 


9. Write MRBLR with the maximum bytes per receive buffer. For this case, assume 16 
bytes, so MRBLR = 0x10. 


10. Initialize the RX buffer descriptor. Assume the RX data buffer is at Ox00001000 in main 
memory. Write OxBO00 to RX_BD_Status, 0x0 to RX_BD_Length (optional), and 
0x00001000 to RX_BD_Pointer. 
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11. Initialize the TX buffer descriptors. Assume the TX data buffer O is at Ox00004000 in 
main memory. Write 0x9000 to TX_BD_Status 0, 0x2 to TX_BD_Length 0, and 
0x00004000 to TX_BD_ Pointer 0. Assume the TX data buffer 1 is at 0x00004010 in 
main memory. Write OxBCOOO to TX_BD_Status 1, Ox2 to TX_BD_Length 1, and 
0x00004010 to TX_BD_ Pointer 1. 


12. Write Oxffff to the I2CER to clear any previous events. 
13. Write 0x17 to the I2CMR to enable all transmit and receive interrupts. 


14. Write 0x10000 to the CIMR to allow I°C to generate a system interrupt. Write Ox8080 
to the CICR to configure interrupt request level 4 and enable CPM interrupts. 


15. Write 0x01 to the I2ZMOD register to enable the I?C controller. 
16. Set the STR bit in the I2COM register to begin the master read operation. 


16.14 THE PARALLEL I/O PORTS 


The communication processor module supports four general-purpose I/O ports—A, B, C, 
and D. Each pin in the I/O ports can be configured as a general-purpose I/O pin or as a 
dedicated peripheral interface pin. Port A is shared with the serial communication controller 
RXD2 and TXD2 pins, the bank of clocks pins, and some time-division multiplex pins. Port B 
is shared with functions like the IDMA, SMC, SPI, USB, and I?C pins. Port C is shared with 
the RTS, CTS, and CD pins of the serial communication controllers as well as some time- 
division multiplex pins. However, port C is unique in that its pins can generate interrupts to 
the CPM interrupt controller. 


You can configure the pins as an input or output, to have a latch for data output, or to be 
read or written at any time. You can even configure them to be either general-purpose I/O 
or dedicated peripheral pins. Ports A and B have pins that can be configured as open-drain. 
These pins drive a zero voltage, but they three-state when driving a high voltage. 


Note: The port pins do not have internal pull-up resistors. Because of the significant 
flexibility of the MPC823 communication processor module, many dedicated 
peripheral functions are multiplexed onto ports A, B, and C. The functions are 
grouped in such a way as to maximize the usefulness of the pins in the greatest 
number of MPC823 applications. It may be difficult to fully understand the pin 
assignment capability described in this section until you better understand the 
CPM peripherals themselves. 
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16.14.1 Features 


The following is a list of the parallel I/O port’s main features: 


e Port A is 12 Bits 
= ¢ Port B is 16 Bits 
S. ). ¢ Port Cis 12 Bits 
| ¢ Port D is 13 Bits 
© All Ports Are Bidirectional 
e All Ports Have Alternate On-Chip Peripheral Functions — 
e All Ports Are Three-Stated at System Reset 
e All Pin Values can Be Read While the Pin ls Connected to an On-Chip Peripheral 
e Ports A and B have Open-Drain Capability 





e Port C has 12 Interrupt Input Pins 


16.14.2 Port A Pin Functionality 


The 12 port A pins are independently configured as general-purpose I/O pins if the 
corresponding bit in the port A pin assignment register (PAPAR) is cleared. On the other 
hand, each pin is configured as a dedicated on-chip peripheral pin if the corresponding 
PAPAR bit is set. When the port A pin is configured as a general-purpose |/O pin, the signal 
direction for that pin is determined by the corresponding control bit in the port A data 
direction register (PADIR). The port A I/O pin is configured as an input if the corresponding 
PADIR bit is cleared and configured as an output if the corresponding bit is set. All PAPAR 
and PADIR bits are cleared at system reset, thus configuring all port A pins as 
general-purpose input pins. 
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Table 16-41 contains the default description of all port A pin options. 


Table 16-41. Port A Pin Assignment 


| PIN FUNCTION 
SIGNAL PAPAR = 0 PAPAR = 1 PERIPHERALS 
PADIR = 0 PADIR = 1 


PA15 PORT A15 USBRXD GND 













a 
eae [porta | uses | — 
Tex | ronras | roe | 
eae | ronrae | moe +f 






PORT AG TOUT1 CLK2 = GND 
PORTAS | CLK3/TIN2/LITCLKA BRGO2 | CLKS/TIN2/L1TCLKA = BRGO2 
PORT Ad CLK4 TOUT2 CLK4 = GND 


NOTE: The items in bold have open-drain capability. 
The I/O direction for the TDM and SMC2 pins are reversed. See PA8 and PAQ. 


If a port A pin is selected as a general-purpose 1/O pin, it can be accessed through the port 
A data register (PADAT). Data written to the PADAT is stored in an output latch. If a port A 
pin is configured as an output, the output latch data is gated onto the port pin. When PADAT 
is read, the port pin itself is read. If a port A pin is configured as an input, data written to 
PADAT is still stored in the output latch, but is prevented from reaching the port pin. In this 
case, when PADAT is read, the state of the port pin is read. If an input to a peripheral is not 
supplied from a pin, then a default value is supplied to the on-chip peripheral as listed in 
Table 16-41. 
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16.14.3 The Port A Registers 


Port A has four 16-bit, memory-mapped, read/write control registers. 


16.14.3.1 PORT A OPEN-DRAIN REGISTER. The port A open-drain register (PAODR) 
indicates when the port pins are configured in a normal or wired-OR configuration. Three of 
the PAODR bits can be open-drain to correspond t to those pins that have serial channel 


LAA Atha et aii Wa —_.2 


ouput capability. The otner bits are always zero. PAODR is cieared by system resei. 


PAODR 


RESERVED 


Po 
4 
if 
z 
(4 
z 
< 


(IMMR & OxFFFFO000) + 0x954 





Bits O-8—Reserved | 
These bits are reserved and should be set to 0. 


OD0-OD15—Open-Drain Pins 0-15 
0= The I/O pin is actively driven as an output. 


1 = The I/O pin is an open-drain driver. As an output, the pin is actively driven low. 
Otherwise, it is three-stated. 


16.14.3.2 PORT A DATA REGISTER. A read of the port A data (PADAT) register returns 
the data at the pin, regardless of whether the pin is defined as an input or output. This allows 
output conflicts to be found on the pin by comparing the written data with the data on the pin. 
A write to the PADIR is latched and if the bit is configured as an output, the value latched for 
that bit is driven onto its respective pin. PADAT is not initialized and is undefined at reset. 


PADAT 


(IMMR & OxFFFFO000) + 0x956 





Bits O-8—Reserved 
These bits are reserved and should be set to 0. 


D4—D15—Data Pins 4-15 
The value written into this field may be read on the Port A pins. 
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16.14.3.3 PORT A DATA DIRECTION REGISTER. The port A data direction (PADIR) 
register is cleared by system reset. 


PADIR 





(IMMR & OxFFFFO000) + 0x950 





Bits O-3—Reserved 
These bits are reserved and should be set to 0. 


DR4—DR15—Pin 4-15 Direction 


O= The corresponding pin is an input. 
1 = The corresponding pin is an output. 


16.14.3.4 PORT A PIN ASSIGNMENT REGISTER. The port A pin assignment register 
(PAPAR) is cleared at system reset. 


(IMMR & OxFFFFO000) + 0x952 





Bits O-3—Reserved 
These bits are reserved and should be set to 0. 


DD4—DD15—Dedicated Peripheral Pins 4-15 | 


O = General-purpose I/O. The peripheral functions of the pin are not used. 
1 = Dedicated peripheral function. The pin is used by the internal module. The 
on-chip peripheral function to which it is dedicated can be determined by other bits. 
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16.14.4 Port A Example Configurations 


The port A pins can be configured in many ways. PA15 can be configured as a 
general-purpose I/O pin, but not an open-drain pin. It can also be the USBRXD pin for the 
USB. If it is configured as a general-purpose |/O pin, the USBRXD input is internally 
grounded. Figure 16-131 and Figure 16-132 illustrate the block diagrams of the PA15 and 
\ PA14 pins. | 


: . 
{ ‘SilelOra! 


(3 


PA14 can be configured as a general-purpose 1/O pin, either open-drain or not. It can also 
be the USBTXD pin for the USB. If USBTXD is configured as an output on PA14 and the 
OD14 bit is set in the PAODR, then USBTXD is output from the USB as an open-drain 
output. If PA14 is configured as a general-purpose I/O pin, then the USBTXD output is not 
externally connected. 


a x 
coh = at 1 | = 4 ~\ 


BIT 15 EN USBRXD/PA15 


OUTPUT PIN 


LATCH 





TO _ USBRXD 
USB 





ane hen 


PAPAR 


Figure 16-131. Parallel Block Diagram For PA15 
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x 





TO | MUX 
PADAT 
BIT 14 USBTXD/PA14 
PIN 
TO _USBTXD . 
USB 


PAODR 





| teers | | | 


PAPAR 
Figure 16-132. Parallel Block Diagram For PA14 


PA7 can be configured as a general-purpose I/O pin, but not an open-drain pin. If the 
corresponding PADIR bit is a zero, it can also be the CLK1 pin, the TIN1 pin, the L1RCLKA 
pin, or all three at once. There is nothing to select other than these three inputs in port A 
because the connections are made separately in the serial interface and timer mode 
registers. If the PADIR bit is a 1, this pin can also be the BRGO1 pin. If the PA7 pinis a 
general-purpose |/O pin, then the input to the on-chip peripheral is internally connected to 
BRGO1. Refer to Section 16.7 The Serial Interface with Time-Slot Assigner for more 
details about using the CLK1 and L1RCLKA pins. 


PA4 can be configured as a general-purpose I/O pin, but not an open-drain pin. If the PADIR 
bit is zero, PA4 can also be the CLK4 pin. If the PADIR bit is a 1, PA4 can be the TOUT2 
pin. If the PA4 pin is a general-purpose I/O pin, then the input to the on-chip CLK4 function. 
This option is useful because not all CLK pins can be routed to all serial channels in every 
situation. The ability to send a clock from CLK8 to CLK4 increases the flexibility of this 
assignment process. Refer to Section 16.7 The Serial Interface with Time-Slot Assigner 
for more details. 
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16.14.5 Port B Pin Functionality 


All port B pins can be open-drain and are independently configured as general-purpose 


I/O pins if the corresponding bit in the PBPAR is cleared. They are configured as dedicated 


on-chip peripheral pins if the corresponding PBPAR bit is set. When configured as a 


- general-purpose I/O pin, the signal direction of that pin is determined by the corresponding 


control bit in the PBDIR. The port I/O pin is configured as an input if the corresponding 
PBDIR bit is cleared and as an output if the corresponding PBDIR bit is set. All PBPAR bits 
and PBDIR bits are cleared by total system reset, thus configuring all port B pins as 


general-purpose input pins. Refer to Table 16-42 for a description of all port B pin options. 


lf a port B pin is used as a general-purpose I/O pin, it can be accessed with the PBDAT 
where data is stored in an output latch. If a port B pin is configured as an output, the output 
latch data is gated onto the port pin. When PBDAT is read, the port pin itself is read. lf a port 
B pin is configured as an input, data written to PBDAT is still stored in the output latch, but 
is prevented from reaching the port pin. When PBDAT is read, the state of the port pin is 
read. Many of the port B pins have more than one function, including on-chip peripheral 
functions for SPI, I7C, SMC1, SMC2, TDMa, and LCD. PB27 and PB26 are unusual in that 
their on-chip peripheral functions (BRGO2 and BRGO1) are also used in port A. This allows 
an alternate way to output the BRGO pins if other functions are used. PB18 and PB16 are 
also unusual in that their on-chip peripheral functions (RTS2 and L1RQA) are used in port 
C, which is an alternate location to output these pins if using other functions on port C. 


Table 16-42. Port B Pin Assignment 





PIN FUNCTION 


SIGNAL | 
| PBPAR = 1 INPUT TO ON-CHIP 





PERIPHERALS 
PBDIR = 0 PBDIR = 1 


PB31 PORT B31 SPISEL LCD_A SPISEL=Vpp 
: PB30. | PORT B30 SPICLK SPICLK=GND | 
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16.14.6 The Port B Registers 


Port B has four 16-bit, memory-mapped, read-write control registers. 


16.14.6.1 PORT B OPEN-DRAIN REGISTER. The 16-bit port B open drain register 
(PBODR) indicates when the port pins are configured in a a normal or wired-OR 
configuration. Bits 0 and 15 of this register are reserved. 


\ 
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PBODR 


a 
ee 
(IMMR & OxFFFFO000) + 0xACO 


OD16 | OD17 | OD18 | OD19 | OD20 | OD21 | OD22 | OD23 | OD24 | OD25 | OD26 | OD27 | OD28 | OD29 | OD30 | OD31 
Faw [aw aw [aw [aw [aw] aw] aw [aw [aw mw [aw | aw | aw [| a 


(IMMR & OxFFFF0000) + OxAC2 





OD16—OD31—Open-Drain Pins 16-31 


O= The l/O pin is actively driven as an output. 
1= The I/O pin is an open-drain driver. As an output, the pin is actively driven low. 
Otherwise, it is three-stated. 


Note: SMTXD1 cannot be set as an open-drain driver, regardless of how this register 
is set. 
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16.14.6.2 PORT B DATA REGISTER. A read of the port B data register (PBDAT) returns 
the data to the pin, regardless of whether the pin is defined as an input or output. This allows 
output conflicts to be found on the pin by comparing the written data with the data on the pin. 
A write to the PBDAT is latched and if that bit in the PBDIR is configured as an output, the 
value latched for that bit is driven onto its respective pin. PBDAT can be read or written at 
any time, is not initialized, and is undefined at reset. 


PBDAT | 


for | or | ove] 019] an at | oz | ne [a as | 0 
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aw a | | | a | | | 


IMMR & OxFFFFO000) + 0xAC6 





D16-—31—Data Pins 16-31 
These bits contain data can be read or written from the port B pins. 
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16.14.6.3 PORT B DATA DIRECTION REGISTER. The port B data direction register 
(PBDIR) is cleared at system reset. 


PBDIR 





DR16 | DR17 | DR18 | DR19 | DR20 | DR21 | DR22 | DR23 | DR24 | DR25 


po 


(IMMR & OxFFFFO000) + 0xABA 


DR14—DR31—Data Direction 


O= The corresponding pin Is an input. 
1 = The corresponding pin is an output. 
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16.14.6.4 PORT B PIN ASSIGNMENT REGISTER. The port B pin assignment register 
(PBPAR) is cleared by system reset. 


PBPAR 


RESERVED 





‘wpe , 





DD14—DD31—Dedicated Function 


General-purpose I/O. The peripheral functions of the pin are not used. 

Dedicated peripheral function. The pin is used by the internal module. The on-chip 
peripheral function to which it is dedicated can be determined by other bits such as 
those in the PBDIR. 
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16.14.7 Port B Configuration Example 


You can configure the PB31 pin as a general-purpose I/O or open-drain pin. It can also be 
the LCD_A pin for the LCD controller or the SPI select input SPISEL pin. If PB31 is not 
configured to connect to the LCD_A or SPISEL signal, then the serial peripheral interface 
receives Vpp on that signal. 





16.14.8 Port C Pin Functionality 


Port C consists of 12 general-purpose |/O pins that have interrupt capability. Refer to 
Table 16-43 for a description of all port C pin options. 


Table 16-43. Port C Pin Assignment 


PCPAR=0 PCPAR = 1 


SIGNAL 
PCSO=0 PCSO =1 

rece [rence | onecr | — | uers_| ee-voo 
ecw | roecw | onece | wee | vere | _exr-voo 
eco | ewce | — | — | usr 

ce [rece | — | aca vere 

Pre [| eae 

[Pc [Ponce 







INPUT TO ON-CHIP 
PERIPHERALS 


















LITSYNCA SDACK1 
LiIRSYNCA 


All PCDIR and PCPAR bits are cleared by a total system reset, thus configuring all port pins 
as general-purpose input pins. Notice that the global CPM interrupt mask register is also 
cleared when a total system reset occurs, so if any port C pin is left floating it does not cause 
a false interrupt. 





lf a port C pin is selected as a general-purpose I/O pin, it can be accessed through the 
PCDAT register where written data is stored in an output latch. If a port C pin is configured 
as an output, the output latch data is gated onto the port pin. When the PCDAT register is 
read, the port pin itself is read. If a port C pin is configured as an input, data written to PCDAT 
register is still stored in the output latch, but is prevented from reaching the port pin. In this 
case, when PCDAT register is read, the state of the port pin is read. 
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When the pin is configured as an output, port C interrupts cannot be generated. To configure 
a port C pin as a general-purpose output pin, follow these steps: 

Write the corresponding PCPAR bit with a zero. 

Write the corresponding PCDIR bit with a 1. 

Write the corresponding PCSO bit with a zero (for clarity). 

The corresponding PCINT bit is a “don’t care” bit. 

Write the pin value using the PCDAT register. 


OF a eS 


To configure a port C pin as a general-purpose input pin that does not generate an interrupt, 
follow these steps: 

Write the corresponding PCPAR bit with a zero. 

Write the corresponding PCDIR bit with a zero. 

Write the corresponding PCSO bit with a zero. 

The corresponding PCINT bit is a “don’t care” bit. 


Write the corresponding CIMR bit with a zero to prevent interrupts from being 
generated to the core. 


_ 6. Read the pin value using the PCDAT register. 


Boe, Ie bet 


When a port C pin is configured as a general-purpose I/O input, a change in the port C 
interrupt register (PCINT) causes an interrupt request signal to be sent to the CPM interrupt 
controller. You can program each port C line to assert an interrupt request when a 
high-to-low change occurs or when any change occurs. Each port C line asserts a unique 
interrupt request to the CPM interrupt pending register and has a different internal interrupt 
priority level within the CPM interrupt controller. Refer to Section 16.15 The CPM Interrupt 
Controller for more details. Each request can be masked independently in the CPM 
interrupt mask register. To configure a port C pin as a general-purpose input pin that 
generates an interrupt, follow these steps: 


Write the corresponding PCPAR bit with a zero. 

Write the corresponding PCDIR bit with a zero. 

Write the corresponding PCSO bit with a zero. 

Set the PCINT bit to find out which edges cause the interrupts. 


Write the corresponding CIMR bit with a 1 so that interrupts can be sent to the core. 
Read the pin value using the PCDAT register. 


O20F ee OS 
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The port C lines associated with the CD2 and CTS2 pins have a mode of operation in which 
the pin can be internally connected to the serial communication controller but can also 
generate interrupts. Port C still detects changes on the CTS2 and CD2 pins and asserts the 
corresponding interrupt request, but the serial communication controller simultaneously 
uses the CTS2 and/or CD2 pin to automatically control operation. This allows you to fully 
implement protocols V.24, X.21, and X.21 bis with the assistance of other general-purpose 
I/O lines. To configure a port C pin as a CTS2 or CD2 pin that connects to the serial 
communication controller and generates interrupts, follow these steps: 











Write the corresponding PCPAR bit with a zero. 

Write the corresponding PCDIR bit with a zero. 

Write the corresponding PCSO bit with a 1. 

Set the PCINT bit to find out which edges cause the interrupts. 

Write the corresponding CIMR bit with a 1 so that interrupts can be sent to the core. 
The pin value can be read at any time using the PCDAT register. 


Oy Ob ge Oru 


Note: After connecting the CTS2 or CD2 pins to the serial communication controller, 
you must also choose “normal operation” mode in the DIAG field of the GSMR_L 
to enable or disable SCC2 transmission and reception with these pins. 





The DREQ1 and DREQ2 pins in port C can assert an external request to the RISC 
microcontroller instead of asserting an interrupt to the core. You can program each pin to 
assert an interrupt request when a high-to-low change occurs or any change that as 
configured in PCINT. 


Note: Do not program the DREQ1 and DREQ2 pins to assert external requests to the 
RISC microcontroller, unless instructed to do so by Motorola as part of a RAM 
microcode package. Otherwise, erratic behavior will occur. 





16.14.9 Port C Registers 


You can communicate with the port C using five registers. The port C interrupt control 
register (PCINT) indicates how changes on the pin cause interrupts when they are 
generated with that pin. The port C special options register (PCSO) indicates whether 
certain port C pins can connect to on-chip peripherals and generate an interrupt at the same 
time. The remaining port C registers exist on the other ports as well. However, since port C 
does not have an open-drain capability, there is no open-drain register. 
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16.14.9.1 PORT C DATA REGISTER. A read of the port C data register (PCDAT) returns 
the data to the pin, regardless of whether the pin is defined as an input or output. This allows 
output conflicts to be found on the pin by comparing the written data with the data on the pin. 
A write to the PCDAT is latched and if that bit in the PCDIR is configured as an output, the 
value latched for that bit is driven onto its respective pin. PCDAT can be read or written at 
any time, is not initialized, and is undefined at reset. 


PCDAT 





NOTE: — = Undefined. 


Bits O-3—Reserved 
These bits are reserved and should be set to 0. 


D4—15—Data Pins 4-15 
These bits contain data can be read or written from the port C pins. 


16.14.9.2 PORT C DATA DIRECTION REGISTER. The port C data direction register 
PCDIR) is a 16-bit register that is cleared by system reset. 


PCDIR 





Bits O-3—Reserved 
These bits are reserved and should be set to 0. 


DR4—DR14—Data Direction Pins 4-14 


0 = The corresponding pin is an input. 
1 = The corresponding pin is an output. 
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16.14.9.3 PORT C PIN ASSIGNMENT REGISTER. The port C pin assignment register 
(PCPAR) is a 16-bit register that is cleared by system reset. | 


PCPAR 


RESERVED 


IMMR & OxFFFFO000) + 0x962 





Bits O-3—Reserved 
These bits are reserved and should be set to 0. 


DD14—DD31—Dedicated Function 


O= General-purpose I/O. The peripheral functions of the pin are not used. 

1 = Dedicated peripheral function. The pin is used by the internal module. The on-chip 
peripheral function to which it is dedicated can be determined by other bits such as 
those in the PBDIR. 


-16.14.9.4 PORT C SPECIAL OPTIONS REGISTER. The port C special options (PCSO) 
register is a 16-bit read/write register. Each bit defined in the PCSO corresponds to a port 
C line (PC8—PC11 and PC14—PC15). The PCSO is cleared by reset. 


PCSO 


sit 
Bek 












Sere 


RESERVED CTS2 RESERVED DREQ1 | DREQ2 
ee oe ee a 
(IMMR & OxFFFFO000) + 0x964 


Bits O-7 and 10—13—Reserved 
These bits are reserved and should be set to 0. 


CD2—Carrier Detect 
0 = PC8is a general-purpose interrupt I/O pin. The SCC2 internal CD2 signal is always 
asserted. If PCDIR configures this pin as an input, the pin can generate an interrupt 
to the core, as controlled by the PCINT bits. | 
1 = PC8 is connected to the corresponding SCC2 signal input in addition to being a 
general-purpose interrupt pin. 
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CTS2—Clear To Send 


0 = PC9 is a general-purpose interrupt I/O pin. The SCC2 internal CTS2 signal is 
always asserted. If PCDIR configures this pin as an input, the pin can generate an 
interrupt to the core, as controlled by the PCINT bits. 

1 = PC9 is connected to the corresponding SCC2 signal input in addition to being a 
general-purpose interrupt pin. 


(Ori 


30) 
= 


_—_ PY DREQx— DMA Request to the RISC Microcontroller 


0 = PCx is a general-purpose interrupt I/O pin, with the direction controlled in PCDIR. 
lf PCDIR configures this pin as an input, the pin can generate an interrupt to the 
core, as controlled by the PCINT bits. 

1 = PCx becomes an external request to the RISC microcontroller instead of being a 
general-purpose interrupt pin. The corresponding PCINT bits control when a 
request is generated. 


Note: DREQx should only be set if you are using IDMA. 





16.14.9.5 PORT C INTERRUPT CONTROL REGISTER. The16-bit read/write port C 
interrupt control (PCINT) register whose bits correspond to a port C line to determine 
whether that line asserts an interrupt request when a high-to-low change occurs or when any 
change occurs. The PCINT is cleared by reset. 


PCINT 





(IMMR & OxFFFFO000) + 0x968 


Bits O-3—Reserved. 
These bits are reserved and should be set to 0. 


EDM4—EDM15—Edge Detect Mode for Lines 4-15 
The corresponding port C line asserts an interrupt request. 


0 = Any change on PCx generates an interrupt request. 
1 = High-to low change on PCx generates an interrupt request. 
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16.14.10 Port D Pin Functionality 


The 13 port D pins are independently configured as general-purpose |/O pins if the 
corresponding port D pin assignment register (PDPAR) is cleared. They are configured as 
dedicated on-chip peripheral pins if the corresponding PDPAR bit is set. 


As a general-purpose I/O pin, the signal direction is determined by the corresponding control 
bit in the port D data direction register (PDDIR). The port I/O pin is configured as an input if 
the corresponding PDDIR is cleared and it is configured as an output if the corresponding 
PDDIR is set. All PDPAR and PDDIR pins are cleared at total system reset, which 
configures all port D pins as general-purpose input pins. Refer to Table 16-44 for all the 
port D pin options’ default descriptions. 


Table 16-44. Port D Pin Assignment 


PIN FUNCTION INPUT TO ON-CHIP 
SIGNAL PDPAR = 0 PERIPHERALS 
PDPAR = 1 PDDIR=0 
















PD11 PORT D114 
PD10 PORT D10 
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16.14.11 Port D Registers 


Port D has three 16-bit, memory-mapped, read/write control registers. 


16.14.11.1 PORT D DATA REGISTER. A read of the port D data (PDDAT) register returns 
the data on the pins, regardless of whether the pins are an input or an output. This allows 
output conflicts to be found on the pins by comparing the written data with the data on the 
pins. A write to the PDDIR is latched, and if that bit in the PDDIR is configured as an outnut 
the value latched for that bit will be driven onto its respective pin. PDDAT can be read or 
written at any time. PDDAT is not initialized and is undefined by reset. 








Bits O-3—Reserved 
These bits are reserved and should be set to 0. 


D4—15—Data Pins 4-15 
These bits contain data can be read or written from the port D pins. 


16.14.11.2 PORT D DATA DIRECTION REGISTER. The port D data direction register 
PDDIR) is cleared at system reset. 


PDDIR 





: 
ee a 


SERVED 





Bits O-2—Reserved 
These bits are reserved and should be set to 0. 


DR3—DR14—Data Direction Pins 3-14 


O= The corresponding pin is an input. 
The corresponding pin is an output. 


ooh, 
II 
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16.14.11.3 PORT D PIN ASSIGNMENT REGISTER. The port D pin assignment register 
(PDPAR) is cleared at system reset. 


PDPAR 


RESERVED DDS 


| Oe TO 
CII. 
(IM 


z 





FFO000) + 0x972 ‘ = 


Bits O-2—Reserved 
These bits are reserved and should be set to 0. 


DD3-—DD15—Dedicated Function 


0 = General-purpose I/O. The peripheral functions of the pin are not used. 

1 = Dedicated peripheral function. The pin is used by the internal module. The on-chip 
peripheral function to which it is dedicated can be determined by other bits such as 
those in the PDDIR. 


16.15 THE CPM INTERRUPT CONTROLLER 


The communication processor module’s interrupt controller (CPIC) is the focal point for all 
interrupts associated with the communication processor module and it accepts and 
prioritizes the internal and external interrupt requests from the CPM blocks. It is also 
responsible for generating a vector during the core interrupt acknowledge cycle. 


The CPM interrupt controller receives interrupts from such internal sources as the USB, 
SCC2, SMCs, SPI, I?C, general-purpose timers, and port C parallel I/O pins. The CPM 
interrupt controller allows you to mask each interrupt source. When multiple events within a 
sub-block of the communication processor module cause the interrupt, each event is 
maskable in that sub-block. 


All CPM sub-block interrupt sources are prioritized and bits are set in the CPM interrupt 
pending register (CIPR) where all interrupt sources are assigned one programmable priority 
level (O—7) before the request for an interrupt is sent to the U-Bus. An overview of the 
MPC823 interrupt structure is illustrated in Figure 16-133. The lower half of the figure 
illustrates the CPM interrupt controller. 
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Figure 16-133. MPC821 Interrupt Structure 
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Within the CPM interrupt level, the sources are assigned a priority structure. On the 
MPC823, you have some flexibility with the relative priority of the interrupt Sources. 


Once an unmasked interrupt source is pending in the CIPR, the CPM interrupt controller 

sends an interrupt request to the U-Bus at level 0, 1, 2, 3, 4, 5, 6, or 7. The CPM interrupt 

controller then waits for the interrupt to be recognized. After the interrupt request is honored 

by the core, the core acknowledges the interrupt by setting the IACK bit in the CPM interrupt 

vector register. When the IACK bit is set, the CIVR is updated with a 5-bit vector 

corresponding to the sub-block with the highest current priority and the IACK is cleared after 

one clock cycle. ine os 


(CHPAIC. 


16.15.1 Features s 


The following is a list of the CPM interrupt controller's main features: | 





e Twenty-four Interrupt Sources (12 Internal and 12 External) 

e Sources Can Be Assigned to a Programmable Interrupt Level 
e Programmable Priority Between SCC2 and USB 

e Two Priority Schemes for SCC2 and USB 

e Programmable Highest Priority Request 


Fully Nested Interrupt Environment 
¢ Unique Vector Number for Each Interrupt Source 


16.15.2 CPM Interrupt Source Priorities 


The CPM interrupt controller has 24 interrupt sources that assert a programmable interrupt 
request level to the core and the priority between these sources is shown in Table 16-45. 
There is some flexibility in the relative ordering of the interrupts in the table, but, in general, 
the relative priorities are fixed in the descending order shown. An interrupt from the parallel 
I/O signal PC15 has the highest priority and an interrupt from the parallel I/O signal PC4 has 
the lowest. A single interrupt priority number is associated with each table entry. 


Notice the lack of SDMA interrupt sources. SDMA-related interrupts are reported through 

each individual USB, SCC2, SMC, SPI, or |I@C channel. The only true SDMA interrupt source 

is the SDMA channel bus error entry that is reported when a bus error occurs during an 

SDMA access. There are two ways to add flexibility to the table of CPM interrupt priorities 

(the USB/SCC2 relative priority option or the highest priority option). | 
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16.15.2.1 USB AND SCC2 RELATIVE PRIORITY. The relative priority between the USB 


and SCC2 is programmable and can be dynamically changed. In Table 16-45 there is no 


entry for USB and SCC2, but rather there are entries for SCCa, SCCb, SCCc, and SCCd 
because each one of them can be mapped to any of these locations. This is programmed in 
the CICR and can be dynamically changed. You can use this on-the-fly capability to 


implement a rotating priority. 


in addition, there are two ways to group the locations of the SCCa, SCCb, SCCc, and SCCd 
entries—group and spread. In the group scheme, the USB and SCC2 are all grouped 
together at the top of the priority table, anead of most of the other CPM interrupt sources. 
This scheme is ideal for applications where USB and SCC2 function at a very high data rate 
and interrupt latency is very important. In the spread scheme, the USB and SCC2 priorities 
are spread over the table so that other sources can have lower interrupt latencies than the 
USB and SCC2. This scheme is also programmed in the CICR, but it cannot be dynamically 
modified. 


16.15.2.2 HIGHEST PRIORITY INTERRUPT. In addition to the USB and SCC2 relative 
priority option, you can choose one interrupt source to be of highest priority. This highest 
priority interrupt is still within the same interrupt level as the rest of the CPIC interrupts, but 
is serviced prior to any other interrupt in the table. If the highest priority feature is not used, 
select PC15 to be the highest priority interrupt and no modifications to the standard interrupt 
priority order will be made. This highest priority source is dynamically programmable in the 
CICR and it allows you to change a normally low priority source into a high priority source 
for a certain period of time. 
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Table 16-45. Prioritization of CPM Interrupt Sources 


PRIORITY LEVEL INTERRUPT SOURCE MULTIPLE EVENTS 
DESCRIPTION 


1E SCCa (Grouped and Spread) 
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16.15.2.3 NESTED INTERRUPTS. The CPM interrupt controller supports a fully nested 
interrupt environment that allows a high priority interrupt from another CPM source to 
suspend a lower priority interrupt service routine. This nesting is achieved by the CPM 
interrupt in-service register (CISR). The CPM interrupt controller prioritizes all interrupt 
sources based on their assigned priority level. The highest priority interrupt request is 
presented to the core for servicing and the core acknowledges the interrupt by setting the 
IACK bit in the CIVR. 


After the IACK bit is set, the vector number that corresponds to this interrupt is made 
available to the core in the CIVR and the interrupt request is cleared. If there are remaining 
interrupt requests, they are then prioritized and another interrupt request can be presented 
to the core. Upon interrupt, the interrupt mask bit in the machine status register (MSR) is 
cleared to disable further interrupt requests until the software is ready to handle them. Refer 
to Section 6.4.1.2.1 Machine State Register for more information. 


The CISR can be used to allow a higher priority interrupt within the same interrupt level to 
be presented to the core before a lower priority interrupt service is completed. Each bit in 
the CISR corresponds to a CPM interrupt source. When the core acknowledges the interrupt 
by setting the IACK bit of the CIVR, the bits in the CISR is set by the CPM anne eouones 
for that interrupt source. 


Setting the bit prevents any subsequent CPM interrupt requests at this priority level or lower, 
until the servicing of the current interrupt has completed and you clear the in-service bit. 
Pending interrupts for these sources are still set in the CPM interrupt controller during this 
time which means that, in the interrupt service routine for the CPM interrupts, you can 
enable the core interrupt mask to allow higher priority interrupts within this level to generate 
an interrupt request. This capability provides nesting of interrupt requests for CPM interrupt 
level sources. | 


16.15.3 Masking Interrupt Sources in the CPM 


By programming the CPM interrupt mask register (CIMR), you can 1 mask the CPM interrupts © 
to prevent an interrupt request to the core. Each bit in the CIMR corresponds to one of the 
CPM interrupt sources. To enable an interrupt, write a 1 to the corresponding CIMR bit. 
When a masked CPM interrupt source has a pending interrupt request, the corresponding 
bit in the CIPR is still set, even though the interrupt is not generated to the core. By masking 
all interrupt sources in the CIMR, you can implement a polling interrupt servicing scheme for 
the cPM interrupts. 


When a CPM iernage source has multiple interrupting events, you can individually mask 
these events by programming a mask register within that block. Table 16-46 shows the 
interrupt sources that have multiple interrupting events and Figure 16-134 illustrates an 
example of how the masking occurs using the SCC2 as an example. 
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Figure 16-134. Interrupt Request Masking 


16.15.4 Generating and Calculating an Interrupt Vector 


All pending unmasked CPM interrupts are presented to the core in order of priority. The core 
responds to an interrupt request by setting the [ACK bit in the CIVR. The interrupt vector that 
allows the core to locate the interrupt service routine is made available to the core by reading 
the CIVR. For CPM interrupts, the CPM interrupt controller passes an interrupt vector 
corresponding to the highest priority, unmasked, pending interrupt. The CPM interrupt 


controller encoding of the five low-order bits of the interrupt vector is provided in 
Table 16-46. 
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Table 16-46. Encoding the Interrupt Vector 


INTERRUPT INTERRUPT SOURCE INTERRUPT VECTOR 
NUMBER DESCRIPTION | 


Parallel /O—PC15 11114 
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Parallel |/O—PC11 01111 
Parallel /O—PC10 01110 
01101 
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The interrupt vector table is the same as the CPM interrupt priority table except for two 

differences. First, the USB and SCC2 vectors are fixed. They are not affected by the USB 

and SCC2 group mode, spread mode, or the relative priority order of the USB and SCC2. 

Second, an error vector is the last entry in this table. The error vector is issued by the 

communication processor module if it requested one but you masked it before it was | 
serviced by the core and if there were no other pending interrupts. You should provide an 

error interrupt service routine, even if it is simply an rfi instruction. 


16.15.5 Programming the CPM Interrupt Controller 
There are four CPM interrupt controller registers: 


| 


e CPM interrupt configuration register—Defines the overall CPM interrupt attributes. | 


e CPM interrupt pending register—Indicates which CPM interrupt sources require 
interrupt service. 


e CPM interrupt mask register—Allows you to prevent any CPM interrupt source from 
generating an interrupt request. 


e CPM interrupt in-service register—Allows a fully nested environment capability for 
interrupt requests within the CPM interrupt level. 


16.15.5.1 CPM INTERRUPT CONFIGURATION REGISTER. The 24-bit read/write CPM 
interrupt configuration register (CICR) defines the request level for the CPM interrupts, the 
priority between the USB and SCC2 and the highest priority interrupt. 


CICR 
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Bits O-7 and 25—-30—Reserved 
These bits are reserved and should be set to 0. 


SO. | 
go. 
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SCdP—SCCd Priority Order 
This field defines whether USB or SCC2 will assert its request in the SCCd priority position. 


00 = USB will assert its request in the SCCd position. 
01 = SCC2 will assert its request in the SCCd position. 


SCcP—SCCc Priority Order : 
This fieid defines whether USB or SCC2 will assert its request in the SCCc priority position. 


00 = USB will assert its request in the SCCc position. 
01 = SCC2 will assert its request in the SCCc position. 


SCbP—SCCb Priority Order 


This field defines the serial communication controller that asserts its request in the SCCb 
priority position. 


00 = USB asserts its request in the SCCb position. — 
01 = SCC2 asserts its request in the SCCb position. 


SCaP—SCCa Priority Order 


This field defines the serial communication controller that asserts its request in the SCCa 
priority position. 


00 = USB asserts its request in the SCCa position. 
01 = SCC2 asserts its request in the SCCa position. 


Note: You should not program USB or SCC2 to more than one priority position (a, b, c, 
or d). These bits may be changed dynamically. 


IRL—Interrupt Request Level 


This field contains the priority request level of the interrupt from the communication _ 
processor module that is sent to the core. Level 0 indicates the highest priority interrupt and 
level 7 indicates the lowest. The IRL field is initialized to zero during reset. In most systems, 
value 0x4 is a good value to choose for these bits. 


10 = Reserved. 
11 = Reserved. 


HP—Highest Priority 


This field specifies the 5-bit interrupt number of the single CPM interrupt controller's interrupt 
source that is advanced to the highest priority in the table. These bits can be dynamically 
modified. To keep the original priority order intact, simply program these bits to 11111. 


16-496 ~ MPC823 USER’S MANUAL ~ MOTOROLA 


Communication Processor Module 


lEN—Interrupt Enable 
This bit is a master enable for the CPM interrupts. 


0 = CPM interrupts are disabled 
1 = CPM interrupts are enabled 


SPS—Spread Priority Scheme 


This bit selects the relative USB or SCC2 priority scheme and cannot be changed 
dynamically. 


O= Grouped. The USB or SCC2 are grouped by priority at the top of the table. 
= Spread. The USB or SCC2 are spread by priority in the table. 


16.15.5.2 CPM INTERRUPT PENDING REGISTER. Each bit in the 32-bit read/write CPM 
interrupt pending register (CIPR) corresponds to a CPM interrupt source. When a CPM 
interrupt is received, the CPM interrupt controller sets the corresponding bit in the CIPR. 


CIPR 


cis | use | scc2 | RESERVED | pct4 sae pci3 | pci2 | SDMA | IDMAt | IDMA2 | res | ™ TIMER cate 
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(IMMR & ee + 0x944 


(IMMR & OxFFFFO000) + 0x946 





In a vectored interrupt scheme, the CPM interrupt controller clears the bit in the CIPR that 
corresponds to the current interrupt when the core acknowledges the interrupt. The core 
acknowledges the interrupt by setting the [ACK bit in the CIVR. The vector number that 
corresponds to the CPM interrupt source is then available to the core in the CIVR. However, 
the CIPR bit is not cleared if an event register exists for that interrupt source. Event registers 
only exist for interrupt sources that have multiple source events. For example, the serial 
communication controller has multiple events that cause serial communication controller 
interrupts. 
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Ina polled interrupt scheme, you must periodically read the CIPR. When a pending interrupt 
is handled, clear the corresponding bit in the CIPR. However, if an event register exists, 
clear the unmasked event register bits instead, thus causing the CIPR bit to be cleared. To 
clear a bit in the CIPR, write a 1 to that bit. Since you can only clear bits in this register, bits 
written as zeros are unaffected. The CIPR is cleared at reset. 


D 


7 Note: The USB or SCC2 CIPR hit positions are not changed according to the relative 
priority between USB or SCC2 (as determined by the SCxP and SPS bits in the 
CICR). Writing a zero to a bit in the CIPR has no effect. 


16.15.5.3 CPM INTERRUPT MASK REGISTER. Each bit in the 32-bit read/write CPM 
interrupt mask register (CIMR) corresponds to a CPM interrupt source. You can mask an 
interrupt by clearing the corresponding bit in the CIMR and you can enable one by setting 
the corresponding bit inthe CIMR. When a masked CPM interrupt occurs, the corresponding 
bit in the CIPR is still set, regardless of the CIMR bit, but no interrupt request is passed to 
the core. 


lf a CPM interrupt source is requesting interrupt service when you clear its corresponding 

bit in the CIMR, the request stops. If you set its bit in the CIMR later, a previously pending 
interrupt request is processed by the core, according to its assigned priority. You can read 
the CIMR at any time and it is cleared by reset. 


CIMR 
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Note: The USB or SCC2 CIMR bit positions are unaffected by the relative priority 
between USB or SCC2. To clear bits that were set by multiple interrupt events, 
you must clear all the unmasked events in the corresponding event register. If a 
bit in the CIMR is masked at the same time that the corresponding CIPR bit 
Causes an interrupt request to the core, then the interrupt is not processed, but 
the error vector is issued if the interrupt acknowledge cycle occurs with no other 
CPM interrupts pending. Thus, you should always include an error vector routine, 
even if it just contains the rfi instruction. The error vector cannot be masked. 


16.15.5.4 CPM INTERRUPT IN-SERVICE REGISTER. Each bit in the 32-bit read/write 
CPM interrupt in-service register (CISR) corresponds to a CPM interrupt source. In a 
vectored interrupt environment, the CPM interrupt controller sets the CISR bit when the core 
acknowledges the interrupt by setting the [ACK bit in the CPM interrupt vector register. Your 
interrupt service routine must clear this bit after servicing is complete. If an event register 
exists for this peripheral, its bits would normally be cleared as well. To clear a bitin the CISR, 
write a 1 to that bit. Since you can only clear bits in this register, bits written as zeros will not 
be affected. The CISR is cleared by reset. 


CISR 
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You can read this register to determine the interrupt requests that are currently in progress 
for each CPM interrupt source. More than one bit in the CISR can be a 1 if higher priority 
CPM interrupts are allowed to interrupt lower priority level interrupts within the same CPM 
interrupt level. For example, the TIMER1 interrupt routine could interrupt the handling of the 
TIMER2 routine using a special nesting technique described earlier. During this time, you 
can see both the TIMER2 and the TIMER1 bits simultaneously set in the CISR. 
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Note: The USB or SCC2 CISR bit positions are not affected by the relative priority 
between USB or SCC2. If the error vector is taken, no bit in the CISR is set. All 
undefined bits in the CISR return zeros when read. You can control the extent to 
which CPM interrupts can interrupt other CPM interrupts by selectively clearing 
the CISR. A new interrupt is processed if it has a higher priority than the higher 
priority interrupt having its CISR bit set. Thus, if an interrupt routine sets the 
interrupt mask bit in the core and also clears its CISR bit at the beginning of the 
interrupt routine, a lower priority interrupt can interrupt the higher one, as long as 
the lower priority interrupt is of higher priority than any other CISR bits that are 
currently set. 


16.15.5.5 CPM INTERRUPT VECTOR REGISTER. The CPM interrupt vector register 
(CIVR).is a 16-bit register. Bits 0-4 of the register contain the interrupt vector number. To 
update the register with the current interrupt vector number, the core should set the [ACK 
bit. The bit is cleared after one clock cycle. The register can be read at any time. 


CIVR 


VECTOR NUMBER RESERVED [ACK 





(IMMR & OxFFFFO000) + 0x930 


~16.15.6 Interrupt Handling Examples 


You can use the following examples to learn how to properly handle CPM interrupts. 
However, there is nothing here about nesting interrupts within the CPM interrupt level. 


16.15.6.1 PC6 INTERRUPT HANDLER EXAMPLE. In this example, the CPM interrupt 
controller hardware clears the PC6 bit in the CIPR during the interrupt acknowledge cycle. 
The following steps show you how to handle an interrupt source without multiple events. 
Set the IACK bit in the CIVR. 

Read the vector to access interrupt handler. 

Handle the event associated with a change in the state of the PC6 pin. 

Clear the PC6 bit in the CISR. 

Execute the rfi instruction. 


OE, ae SOO ae 
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16.15.6.2 USB INTERRUPT HANDLER EXAMPLE. In this example, the USB bit in the 
CIPR remains set as long as one or more unmasked event bits remain in the USBE register. 
This is an example of a handler for an interrupt source with multiple events. Notice that the 
bit in the CIPR does not need to be cleared by the handler, but the bit in the CISR does. 


Set the IACK bit in the CIVR. 
Read the vector to access interrupt handler. 


Immediately read the USBE register into a temporary location. 


Decide which events in the USBE will be handled in this handler and clear those bits 
as soon as possible. USBE bits are cleared by writing ones. 


Handle the events in the USB RX or TX buffer descriptor tables. 
Clear the USB bit in the CISR. 


7. Execute the rfi instruction. If any unmasked bits in the USBE remain at this time (either 
not cleared by the software or set by the MPC823 during the execution of this handler), 
this interrupt source is once again made pending immediately following the rfi 
instruction. 
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SECTION 17 
PCMCIA INTERFACE 


The PCMCIA host adapter module provides all control logic for a PCMCIA interface. Only 
the analog power switching logic and buffering needs to be provided externally. The 
PCMCIA host supports one PCMCIA socket. 


17.1 FEATURES 
The following list summarizes the main features of the PCMCIA interface: 
e A Host Adapter Interface Fully Compliant with the PCMCIA Standard, Release 2.1+ 


(PC Card -16). 


e Supports One PCMCIA Socket, Requiring Only External Buffering and Analog 
Switching Logic. The Socket Is Referred to As Slot B to Maintain Compatibility with the 
MPC821 Microprocessor. 


Supports Eight Memory or I/O Windows. 


Provides Eight General-Purpose I/O Pins When the PCMCIA Controller Is Not In 
Operation. 


Provides Two General-Purpose Output-Only Pins When the PCMCIA Controller Is Not 
In Operation. 


17.2 SYSTEM CONFIGURATION 


The PCMCIA host adapter interface module can control one PCMCIA socket, which is 
illustrated in Figure 17-1. In this system configuration, you must accomplish electrical 
isolation between the sockets and system bus using external buffers and bus transceivers. 
These buffers also provide the voltage conversion needed from the MPC823’s 3.3V to 5V 
cards. They should be powered by the card V,,. Since the MPC823 is 5V friendly and will 
accept 5V inputs while generating 3.3V outputs, no conversion is needed for inputs. — 
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WAIT_B, lOIS16_B 


RDY/BSY_B, BVD1_B,BVD2_B 
CHIP VDD 


CD1_B, CD2_B, VS1_B, VS2_B 


SPKROUT 


Figure 17-1. System with One PCMCIA Socket 
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17.3 PCMCIA SIGNALS 


The PCMCIA module consists of the cycle control, input port, output port, and various other 
signals. 


17.3.1 The PCMCIA Cycle Control Signals 


The following signals are used for I/O accesses to the PCMCIA card: 


e Address Bus (A[6:31])—Output. These signals should be buffered to generate the 
socket’s A25 through AO signals, which are address bus output lines that allow direct 
addressing of up to 64M of memory on each PCMCIA card. Signal A6 is the 
most-significant bit and A31 is the least-significant bit. 


Attribute Memory Select (REG)—Output. When this signal is asserted during a 
PCMCIA access, card access is limited to attribute memory when a memory access 
occurs (WE or OE are asserted), and to I/O ports when an I/O access occurs (IORD or 
lIOWR are asserted). On accesses with REG asserted, accesses to common memory 
or DMA devices are blocked. When no PCMCIA access is performed this signal is 
TSIZO. 


Card Enables (CE1_B, CE2_B)—Output. When a PCMCIA access is performed, the 
CE1 and CE2 signals are card enable output signals. The CE1 signal enables even 
bytes and CE2 enables odd bytes. 





The CE signals can be configured to duplicate the values of the A[22:23] signals. At the 
end of the PCMCIA access these lines will be always negated. See Table 17-1 for 
details. This feature can be used to access devices supporting IDE/ATA protocols. 


Table 17-1. Card Enable as Driven by the MPC823 


PRS PORT ACCESS MPC823: A31 | CE2 | CE1 
fee. SIZE SIZE (SLOT: AO) | 
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8 bits even 
No access 
PRS = ‘110’ 
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e Data Bus (D[0:15])—Bidirectional. Signals DO through D15 constitute the bidirectional 
data bus. The most-significant bit is DO. Significance decreases downward to D15. 


Extend Bus Cycle (WAIT_B)—Input. This signal is asserted by the PC card to delay 
completion of the pending memory or I/O cycle. 


External Transceiver Direction (R/W)—Output. This signal is part of the MPC823 bus. 
lt is asserted or driven high during any read cycles of the MPC823 and negated or 


driven low during write cycles. It is used in the PCMCIA interface to contro! the direction 


ww ~J we ww wee awe wet le ws 


of the data bus transceivers. 


I/O Read (IORD_B)—Output. During PCMCIA accesses, this signal is asserted in 
conjunction with REG_B. It is used to read data from the PC card’s I/O space. IORD_B 
is valid only when the REG_B and at least one of CE1_B and CE2_B signals is 
asserted. 


I/O Write (IOWR_B)—Output. During PCMCIA accesses, this signal is asserted in 
conjunction with REG_B. It is used to latch data into the PC card’s I/O space. IOWR_B 
is valid only when the REG_B and at least one of CE1_B and CE2_B signals is 
asserted. 


Output Enable (OE_B)—Output. During PCMCIA accesses, the OE_B signal is used to 
drive memory read data from a PC card into a PCMCIA socket. 


Write Enable/Program (WE_B)—Output. During PCMCIA accesses, the WE_B signal 
is used to latch memory write data to the PC card in a PCMCIA socket. This signal can 
also be used as the programming strobe for PC cards employing programmable 
memory technologies. 


Address Latch Enable (ALE_B)—Output. This strobe signal controls the external 
buffers of the Address and REG signals. 


I/O Port Is 16 Bits (1OIS16_B)—Input. When the card and its socket are programmed 
for I/O interface operation, this signal is used as 1|OIS16_B and must be asserted by the 
card when the address on the bus corresponds to an address on the PC card and the 
I/O port being addressed is capable of 16-bit accesses. If the I/O region in which the 
address resides is programmed as 8 bits wide, then the l|OIS16_B signal is ignored. 
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17.3.2 The PCMCIA Input Port Signals 


The MPC823 provides synchronization, transition detection, optional interrupt generation 
and a means for the software to read the signal state. This function is not necessarily 
specific to PCMCIA and the signals can be used as a general-purpose input port with edge 
detection and interrupt capability. 


The following signals are used by a PCMCIA slot to indicate the status of the card. They 
appear on the IP_B[0:7] pins, which you can access through bits 16-23 of the PIPR when 
you are not operating the PCMCIA controller. All these signals are symmetrical except for 
IP_B[7], which has extended edge detection capability, and IP_B[2] that serves as 
lOIS16_B cycle control signals for PCMCIA cycles. 


Voltage Sense (VS1_B, VS2_B)—Input. These signals are used as VS1 and VS2 and 
are generated by PC cards. They notify the socket of the card’s Vo, requirement. These 
signals are connected to the IP_B[0:1] pins. 


Write Protect (WP)—Input. When the card and its socket are programmed for memory 
interface operation, this signal is used as WP and reflects the status of the write protect 
switch on the PC card. It must be asserted by the PC card when the switch is enabled 
and negated when the switch is disabled. For a PC card without a switch, this signal 
must be connected to ground if the PC card can be written and connected to system 
Voc if the PC card is permanently write-protected. This signal is connected to the 
IP_B[2] pin. 


Card Detect (CD1_B, CD2_B)—Input. These signals ensure that a card has been 
inserted properly. They must be connected to ground internally on the PC card and they 
will be forced low whenever a card is placed in the socket. These signals must be pulled 
up to system Vc, to allow card detection to function while the card socket is powered 
down. These signals are connected to the IP_B4 and IP_B3 pins, respectively. 


Battery Voltage Detect (BVD1_B, BVD2_B)—Input. When the card and its socket are 
programmed for memory interface operation, these signals are used as BVD1_B and 
BVD2_B and are generated by PC cards having an onboard battery. They report the 
battery’s condition. Both BVD1_B and BVD2_B must be held asserted when the battery 
is in good condition. Negating BVD2_B while keeping BVD1_B asserted indicates the 
battery is in a warning condition and should be replaced, although data integrity on the 
card is still assured. Negating BVD1_B indicates that the battery is no longer. 
serviceable and data is lost, regardless of the state of BVD2_B. These signals are 
connected to the IP_B6 and IP_B5 pins, respectively. 


Status Change (STSCHG)—Input. When the card and its socket are programmed for 
I/O Interface operation, the BVD1_B signal is used as STSCHG,, it is generated by the 
I/O PC card. The STSCHG signal must be held negated when either or both the Signal 
on Change bit and Changed bit in the card status register on the PC card are set to zero. 
The STSCHG signal must be asserted when both bits are set to one. 
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e Speaker (SPKR)—Input. When the card and its socket are programmed for I/O 
interface operation, the BVD2_B signal is used as SPKR and it is generated by the I/O 
PC cards. The SPKR signal must be used to provide the socket’s single amplitude 
(digital) audio waveform to the system. The SPKR signal is routed out the SPKROUT 
signal if the card and its socket are programmed for I/O interface operation. 


Ready/Busy/Interrupt Request (RDY/BSY_B/IREQ_B)—Input. When the card and its 
socket are programmed for memory interface operation, this signal is used as RDY/ 
BSY_B and must be asserted low by a PC card to indicate that the PC card is busy 
processing a previous WRITE command. When the card and its socket are 
programmed for I/O operation, this signal is used as IREQ_B and must be asserted low 
to generate an interrupt. This signal must be set high when no interrupt is requested. 
This signal is connected to the IP_B[7] pin. 


17.3.3 The PCMCIA Output Port Signals 


The following signals are used by a PCMCIA slot to control the RESET signal to the card 
and the output enable of the buffers to the card. The MPC823 provides a way for the 
software to control the output signal state. This function is not necessarily specific to the 
PCMCIA interface and these signals may be used by a system as a general-purpose output 
port. These signals appear on the OP[2:3] pins. The OP[2:3] pins, when not operating the 
PCMCIA controller, can be accessed as general-purpose outputs through the CBOE and 
CBRESET bits of the PGCRB register. 














e Card Reset (RESET_B)—Output. This signal is provided to clear the card configuration 
option register residing on the card, thus placing the card in its default (memory-only 
interface) state and initiating the beginning of any additional card initialization. 
RESET_B is connected to the OPS pin. 


PCMCIA Buffers Output Enable (POE_B)—Output. This line is an output port line 
reflecting the value of the CBOE bit in the PCMCIA interface power control register. It 
should be used to three-state the address and strobe pins addressing the slot. POE_B 
is connected to the OP2 pin. | 








17.3.4 Other PCMCIA Signals 


The following special function signals can be used by the PCMCIA socket. Their function is 
not necessarily speqne’ to PoMeue and these signals can be used by a system for other 
functions. 


¢ Power Is On (IRQ)—Input. One IRQ signal provided for general-purpose interrupt 
requests may be used by the card power supply circuitry to notify the MPC823 
processor when the power supply to the card has reached the required voltage. 


¢ Speaker out (SPKROUT)—Output. This signal is used to provide a digital audio 
waveform that is to be driven to the system’s speaker. It is generated from the SPKR 
input port signal. 
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17.4 PCMCIA OPERATION 
17.4.1 Memory-Only Cards 


Table 17-2 shows a worst case example of host programming. 


Table 17-2. Host Programming for Memory Cards 


MEMORY 





r- 
-/-42/ny]o] a 2 
@) 


Note: Because the minimum hold time is one clock, the real access time is, access time 
plus one clock. Hold time and setup time HLD and STP, in this table, are the read 
or write worst case. The worst case hold time is “data disable from OE. The worst 
case setup time is address to strobe. Length (LNG) in this table is the minimum 
strobe time. 





Table 17-2 assumes you are not using the WAIT_B signal. If you are using the WAIT_B 
signal, then the minimum strobe time is at least 35ns + 1 system clock. 


17.4.2 I/O Cards 


Table 17-3 shows a worst case example of programming PCMCIA host for !/O cycle. 
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Table 17-3. Host Programming For I/O Cards 





Setup time worst case is for write, in which case, setup = data_setup_before_IORD +1 
system clock. 
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17.4.3 Interrupts 


Each input from the PCMCIA card to the host (BVD,CD,RDY, and VS) is sampled in the 
PCMCIA interface input pins register (PIPR) and any change to these bits is reported in the 
PCMCIA interface status change register (PSCR). The contents of the PSCR is AND’ed with 
the PCMCIA interface enable register (PER) to generate a PCMCIA interface interrupt. You 
can program the interrupt level for the exception that is generated. The PCMCIA interface 
can generate an additional interrupt for the RDY/IRQ signal. This interrupt can be generated 
for level (low or high) and for change (fall or rise) of the input signal. 


17.4.4 Power Control 


You can perform a write cycle using one of memory controller’s CS signals, so that you can 
operate an external device to provide a regulated source voltage to the PCMCIA slot. There 
are a number of such devices available. However, auto-power control is not supported. 


17.4.5 Reset and Three-State Control 


You can write to the right bit in the PCMCIA general interface control register B (PGCRB) 
and cause the PCMCIA card to be reset or to disable the output drive of the external latches. 


17.4.6 DMA 


The MPC823’s DMA module with the CPM microcode provides two independent DMA 
channels. The PCMCIA module can be programmed to generate control for an I/O device 
implemented as a PCMCIA card to act upon a DMA transfer. You can use the PRS field in 
the appropriate POR to program any window to be a DMA window. The PCMCIA controller 
supplies the signaling for the socket. DMA to or from the PCMCIA interface is done through 
dual-access DMA transfers. DMA requests can be supplied through the SPKR, lOIS16_B or 
INPACK signals. To support the DMA function, the slot’s INPACK should be connected to 
DREQ2. The actual source used for a DMA request is programmed in the CBDREQ[0:1] 
field of the PGCRB register. If the internal DMA request is enabled, then port C should be 
programmed to not DREQ2. When the internal DMA request is disabled, then the DMA 
request is assumed to be DREQ2. In this case, you should program port C so that the PC 14 
pin is DREQ2. 























Note: The PCMCIA controller will monitor the SDACK2 signal internally to meet the 
IDMA handshaking protocol. Therefore, you do not have to monitor this signal for 
your PCMCIA design. | 


17-8 MPC823 USER’S MANUAL MOTOROLA 


PCMCIA Interface 





IOIS16_B_ SPKR CBDREQ1 DREQ2 








CBDREQ2 
MULTIPLEXER 


PORT C DREQ2 


INTERNAL DMA REQUEST 


Figure 17-2. Internal DMA Request Logic 


17.5 PCMCIA PROGRAMMING MODEL 


The following section describes the PCMCIA interface programming model. All registers are 
memory-mapped within the internal control register area. The following registers are used 
to control the PCMCIA interface. 


17.5.1 PCMCIA Interface Input Pins Register 


The PCMCIA interface input pins register (PIPR) is used to sample the PCMCIA input port 
signals. When the PCMCIA controller is not operating, bits 16-23 of the PIPR can be used 
to read from and write to the IP_B[0:7] pins as general-purpose 1/O pins. 
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RESERVED 


(IMMR & OxFFFFO000) + OxFO 





NOTE: — = Undefined. 


Bits O—15—Reserved 
These bits are reserved and should be set to 0. 
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PCMCIA Interface 


CBVS1—Card B Voltage Sense 1 


O= Card B cannot operate at 3.3V. 
1 = Card B can operate at 3.3V. 


CBVS2—Card B Voltage Sense 2 


This bit is reserved by the PCMCIA controller for a secondary operating voltage. It should 
normally be set to 1 by Card B. 


CBWP—Card B Write-Protect 


0 = Card B is not write-protected. It cannot be written to. 
1 = Card B is write-protected. 


CBCD2—Card B Card Detect 2 


0 = Card B is fully connected in socket. 
1 = Card B is not properly connected in socket. 


CBCD1—Card B Detect 1 


0 = Card B is fully connected in socket. 
1 = Card B is not properly connected in socket. 


CBBVD2—Card B Battery Voltage 2/SPKR 

If Card B and its socket are configured for I/O interface operation, this bit reflects the value 
of the SPKR signal. If Card B and its socket are configured for memory interface operation 
and Card B has an onboard memory, CBBVD2 is: 





XO = Card B battery is no longer serviceable and data is lost. 

01 = Card B battery is in a warning condition and should be replaced. Card B data 
integrity is still assured. 

11 = Card B battery is in good condition. 


CBBVD1—Card B Battery Voltage 2/STSCHG 


If Card B and its socket are configured for I/O interface operation, this bit reflects the value 
of the STSCHG signal. If Card B and its socket are configured for memory interface 
operation and Card B has an onboard memory, CBBVD1 is: 


XO = Card B battery is no longer serviceable and data is lost. 

01 = Card B battery is in a warning condition and should be replaced. Card B data 
integrity is still assured. | 

11 = Card B battery is in good condition. 


CBRDY—Card B RDY/BSY_B/IREQ_B/IRQ 
If Card B and its socket are configured for memory interface operation, CBRDY is: 


0 = Card B is busy. 
1 = Card B is ready to accept a new data transfer operation. 
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lf Card B and its socket are configured for I/O interface operation or if the card’s power 
supply circuitry is using the IRQ signal, CBRDY is: 


0 
1 


Card B is requesting an interrupt. 
Card B is not requesting an interrupt. 


Bits 24—31—Reserved 
These bits are reserved and should be set to 0. 


17.5.2 PCMCIA Interface Status Change Register 


The PCMCIA interface status change register (PSCR) records changes in the state of the 
PCMCIA input port signals. The nonreserved bits in this register are reset by writing ones to 
them. Writing zero has no effect. 


ee 


CBBVD | CBBVD CBRDY | CBRDY | CBRDY | CBRDY 
- 2C: |) 16 wi H R F 


(IMMR & OxFFFFO000) + 0xE8 





NOTE: — = Undefined. 


Bits O-15—Reserved 
These bits are reserved and should be set to 0 


CBVS1_C—Card B Voltage Sense 1 Change 


O= Signal is changed. 
1 = Signal is unchanged. 


CBVS2_C—Card B Voltage Sense 2 Change 


O= Signal is changed. 
1 = Signal is unchanged. 


CBWP_C—Card B Write-Protect Change 


O= Signal is changed. 
Signal is unchanged. 


— 
| 
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CBCD2_C—Card B Card Detect 2 Change 


0 = Signal is changed. 
1 = Signal is unchanged. 


CBCD1_C—Card B Card Detect 1 Change 


0 = Signal is changed. 
1 = Signal is unchanged. 


CBBVD2_C—Card B Battery Voltage 2/SPKR Change 
0 = Signal is changed. 
1 = Signal is unchanged. 
CBBVD1_C—Card B Battery Voltage 1/STSCHG Change 
0 = Signal is changed. 
1 = Signal is unchanged. 


Bit 23—Reserved 
This bit is reserved and should be set to 0. 


CBRDY_L—Card B RDY/IRQ Low 
0 = Signal is changed. 
1 = Signal is unchanged. 


CBRDY_H—Card B RDY/IRQ High 

0 = Signal is changed. 

1 = Signal is unchanged. 
CBRDY_R—Card B RDY/IRQ Rising Edge 

O= Signal is changed. 

1 = Signal is unchanged. 
CBRDY_F—Card B RDY/IRQ Falling Edge 

0 = Signal is changed. 

1 = Signal is unchanged. 


Bits 28—31—Reserved 
These bits are reserved and should be set to 0 


Note: Writing logic one to each bit reset it’s value (zero), except for bit 9 which is always 
set to one. 
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17.5.3 PCMCIA Interface Enable Register 


The PCMCIA interface enable register (PER) acts as a mask for the various sources of a 
PCMCIA interrupt. 


PER 


RESERVED 
(IMMR & OxFFFFO000) + OxF8 | 
oe ane r score memes wane a 


= 


é : "ye i i : 
CB_EV | CB_EV | CB_LEW | CB_EC | CB_EC | CB_EB } CB_EB CB_ER | CB_ER ] CB_ER | CB_ER 
| | wr | row | eo { woe] re | ow |r | ow | | | 


(IMMR & OxFFFFO000) + OxF8 





BE 


NOTE: — = Undefined. 


Bits O—15—Reserved 
These bits are reserved and should be set to 0. 


CB_EVS1—Card B Enable for Voltage Sense 1 


0 = Disable interrupt on any change in the relevant pin. 
1 = Enable interrupt on changes of the relevant pin. 


CB_EVS2—Card B Enable for Voltage Sense 2 


0 = Disable interrupt on any change in the relevant pin. 
1 = Enable interrupt on changes of the relevant pin. 


CB_EWP—Card B Enable for Write-Protect 


0 = Disable interrupt on any change in the relevant pin. 
1 = Enable interrupt on changes of the relevant pin. 


CB_ECD2—Card B Enable for Card Detect 2 


0 = Disable interrupt on any change in the relevant pin. 
1 = Enable interrupt on changes of the relevant pin. 


CB_ECD1—Card B Enable for Card Detect 1 


0 = Disable interrupt on any change in the relevant pin. 
1 = Enable interrupt on changes of the relevant pin. 
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PCMCIA Interface 


CB_EBVD2—Card B Enable for Battery Voltage/SPKR 


0 = Disable interrupt on any change in the relevant pin. 


1 = Enable interrupt on changes of the relevant pin. 


CB_EBVDi—Card B Enable for Battery Voltage/STSCHG 


0 = Disable interrupt on any change in the relevant pin. 


ee a ed 


1 = Enable interrunt on changes of the relevant pin. 


Bit 23—Reserved 
This bit is reserved and should be set to 0. 


CB_ERDY_L—Card B Enable for RDY/IRQ Low 


0 = Disable interrupt on any change in the relevant pin. 


_~1= Enable interrupt on changes of the relevant pin. 


CB_ERDY_H—Card B Enable for RDY/IRQ High 


0 = Disable interrupt on any change in the relevant pin. 


1 = Enable interrupt on changes of the relevant pin. 


CB_ERDY_R—Card B Enable for RDY/IRQ Rising Edge 


O = Disable interrupt on any change in the relevant pin. 


1 = Enable interrupt on changes of the relevant pin. 


CB_ERDY_F—Card B Enable for RDY/IRQ Falling Edge 


0 = Disable interrupt on any change in the relevant pin. 


1 = Enable interrupt on changes of the relevant pin. 


Bits 28-31—Reserved 
These bits are reserved and should be set to 0. 
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17.5.4 PCMCIA Interface General Control Register B 


The PCMCIA interface general control register B (PGCRB) provides control for the IREQ 
and STSCHG interrupt levels, This register also controls the PCMCIA output port signals. 
When the PCMCIA controller is not operating, the CBOE and CBRESET bits can be used 
to access the OP[2:3] pins as general-purpose output pins without configuring any other 
PCMCIA register. 


PGCRB 












CBIRQLVL CBSCHLVL 
(IMMR & OxFFFFO000) + 0xE4 


CBDREQ RESERVED CBOE ras RESERVED 
: (IMMR & OxFFFFO000) + OxE4 


NOTE: — = Undefined. 













CBIRQLVL—Card B Interrupt Request Level 
Only one bit of this field should be set at any given time. 


CBSCHLVL—Card B STSCHG Level | 
Only one bit of this field should be set at any given time. 


CBDREQ—Card B DMA Request 
This field defines the pin to be used as the internal DMA request to IDMA channel 2. 


Ox = Disable internal DMA request from Slot B. 
10 = Enable IOIS16_B as internal DMA request for Slot B. 
11 = Enable SPKR as internal DMA request for Slot B. 


Note: If the PCMCIA controller is programmed to enable internal DMA, then the port C 
registers should be configured to NOT select DREQ2. Otherwise, DREQ2 
should be configured. 





Bits 18-23—Reserved 
These bits are reserved and should be set to 0. 
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CBOE—Card B Output Enable 


This bit is reflected on the OP2 pin that is used to three-state the external buffers when the 
card’s power is activated. When the PCMCIA controller is in active mode: 


OP2 is low. 
OP2 is high. 


0 
1 


CBRESET—Card B Reset 


This bit is reflected on the OPS pin used to reset the card. When the PCMCIA controller is. 
in active mode: 


OPS is low. 
OP3 is high. 


0 
{ 


Bits 26—31—Reserved 
These bits are reserved and should be set to 0. — 


17.5.5 PCMCIA Base Registers 7 


The PCMCIA base registers 0O—7 (PBRO-7) contain the PCMCIA base addresses for the 
PCMCIA memory or I/O windows. The base registers are used in conjunction with the BSIZE 
field of the corresponding PCMCIA option register to ensure valid PCMCIA accesses. 


PBRO-PBR7 


IMMR & OxFFFFO000) + 0x80 (PBRO), 0x88 (PBR1), 0x90 (PBR2), 0x98 
0xA0 (PBR4), 0xA8 (PBR5), 0xBO (PBR6), 0xB8 (PBR7 
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IMMR & OxFFFFO000) + 0x80 (PBRO), 0x88 (PBR1), 0x90 (PBR2), 0x98 (PBR3), 
0xA0 (PBR4), 0xA8 (PBR5), 0xBO (PBR6), 0xB8 (PBR7 





NOTE: — = Undefined. 


PBA—PCMCIA Base Address 


This field is compared to the address on the address bus to determine if aa PCMCIA window 
is being accessed by an internal bus master. These bits are used in conjunction with the 
BSIZE field in the POR. | 
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17.5.6 PCMCIA Option Registers 


The PCMCIA option registers 0-7 (PORO-POR7) control the size, timing parameters, and 
memory access to the individual PCMCIA windows whose base addresses reside in the 
corresponding PCMCIA base registers. 


PORO-POR7 


(IMMR & OxFFFF0000) + 0x84 (PORO), 0x8C (POR1), 0x94 (POR2), 0x9C (POR3), 
0xA4 (POR4), OxAC (PORS), 0xB4 (POR6), 0OxBC (POR7) 


(IMMR & OxFFFF0000) + 0x84 (PORO), 0x8C (POR1), 0x94 (POR2), 0x9C (POR3), 
0xA4 (POR4), OxAC (PORS), 0xB4 (POR6), 0xBC (POR7) 





NOTE: — = Undefined. 


BSIZE—PCMCIA Bank Size 


This field determines the bank size (the size of the address space in bytes) for the 
corresponding PCMCIA window. The bank size is also used as an address mask and is 
applied to the PBA field in the associated PCMCIA base register to an address generated 
by an internal master. The bank size is calculated from BSIZE as: 


PCMCIA INTERFACE 


BankSize = pGrayCode(BSIZE) 


‘ SF: Ps a 
4 ao ” 





00000 = 1 bytes. 
00001 = 2 bytes. 
00011 = 4 bytes. 
00010 = 8 bytes. 


00110 = 16 bytes. 
00111 = 32 bytes. 
00101 = 64 bytes. 
00100 = 128 bytes. 


01100 = 256 bytes. 
01101 = 512 bytes. 
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01111 = 1K. 
01110 = 2K. 


01010 = 4K. 
01011 = 8K. 
01001 = 16K. 
01000 = 32K. 


11000 = 64K. 

11001 = 128K. 
11011 = 256K. 
11010 = 512K. 


11110 = 1M. 
11111 = 2M. 
11101 = 4M. 
11100 = 8M. 


10100 = 16M. 
— 10101 = 32M. 
10111 = 64M. 


The calculated bank size is used as a mask (MASK) to determine a valid PCMCIA address 
as follows: 


If ((Address & MASK) == (PBA & MASK) ) 
Valid PCMCIA access 

else 
invalid PCMCIA access 
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PSHT—PCMCIA Strobe Hold Time 

This attribute is used to determine when IOWR_B or WE_B are negated during a PCMCIA 
write access or when IORD_B or OE_B are negated during a PCMCIA read access handled 
by the PCMCIA interface. This aids in meeting address/data hold time requirements for slow 
memories and peripherals. 





0000= Strobe negation to Address change 0 clock. 
0001= Strobe negation to Address change 1 clock. 
0010= Strobe negation to Address change 2 clock. 
0011= Strobe negation to Address change 3 clock. 
0100= Strobe negation to Address change 4 clock. 
0101= Strobe negation to Address change 5 clock. 
0110= Strobe negation to Address change 6 clock. 
0111= Strobe negation to Address change 7 clock. 
1000= Strobe negation to Address change 8 clock. 
1001= Strobe negation to Address change 9 clock. 
1010= Strobe negation to Address change 10 clock. 
1011= Strobe negation to Address change 11 clock. 
1100= Strobe negation to Address change 12 clock. 


1101= 
1110= 
1111= 


Strobe negation to Address change 13 clock. 
Strobe negation to Address change 14 clock. 
Strobe negation to Address change 15 clock. 


PSST—PCMCIA Strobe Setup Time 

This attribute is used to determine when IOWR_B or WE_B are asserted during a PCMCIA 
write access or when IORD_B or OE_B are asserted during a PCMCIA read access handled 
by the PCMCIA interface. This aids in meeting address/setup time requirements for slow 
memories and peripherals. 





.©) 
<— 
0000= Reserved i 
0001= Address to Strobe assertion 1 clock cycles. Z 
0010= Address to Strobe assertion 2 clock cycles. = 
0011= Address to Strobe assertion 3 clock cycles. 5S 
0100= Address to Strobe assertion 4 clock cycles. 
0101= Address to Strobe assertion 5 clock cycles. 
0110= Address to Strobe assertion 6 clock cycles. 
0111= Address to Strobe assertion 7 clock cycles. 
1000= Address to Strobe assertion 8 clock cycles. 
1001= Address to Strobe assertion 9 clock cycles. 
1010= Address to Strobe assertion 10 clock cycles. 
1011= Address to Strobe assertion 11 clock cycles. 
1100= Address to Strobe assertion 12 clock cycles. 
1101= Address to Strobe assertion 13 clock cycles. 
1110= Address to Strobe assertion 14 clock cycles. 
1111= Address to Strobe assertion 15 clock cycles. 
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PSL—PCMCIA Strobe Length 3 

This attribute determines the number of cycles the strobe will be asserted during a PCMCIA 
access for this window. It is the main parameter for determining the length of the cycle. The 
cycle may be lengthened by asserting the WAIT signal. 





00001= Strobe asserted 1 clock cycles. 
00010= Strobe asserted 2 clock cycles. 
00011= Strobe asserted 3 clock cycles. 
00100= Strobe asserted 4 clock cycles. 
00101= Strobe asserted 5 clock cycles. 
00110= Strobe asserted 6 clock cycles. 
00111=Strobe asserted 7 clock cycles. 
01000= Strobe asserted 8 clock cycles. 
01001= Strobe asserted 9 clock cycles. 
01010= Strobe asserted 10 clock cycles. 
01011=Strobe asserted 11 clock cycles. 
01100= Strobe asserted 12 clock cycles. 
01101=Strobe asserted 13 clock cycles. 
01110=Strobe asserted 14 clock cycles. 
01111=Strobe asserted 15 clock cycles. 
10000= Strobe asserted 16 clock cycles. 
10001= Strobe asserted 1 7 clock cycles. 
10010= Strobe asserted 18 clock cycles. 
10011=Strobe asserted 19 clock cycles. 
10100= Strobe asserted 20 clock cycles. 
10101= Strobe asserted 21 clock cycles. 
10110=Strobe asserted 22 clock cycles. 
10111=Strobe asserted 23 clock cycles. 
11000= Strobe asserted 24 clock cycles. 
11001=Strobe asserted 25 clock cycles. 
11010=Strobe asserted 26 clock cycles. 
11011=Strobe asserted 27 clock cycles. 
11100= Strobe asserted 28 clock cycles. . 
11101=Strobe asserted 29 clock cycles. 
11110=Strobe asserted 30 clock cycles. 
11111=Strobe asserted 31 clock cycles. 
00000= Strobe asserted 32 clock cycles. 
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PPS—PCMCIA Port Size 
This field specifies the port size of this PCMCIA window. 


0 = 8-bit port size. 
1 = 16-bit port size. 
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PRS—PCMCIA Region Select 


000 = Common memory space. 

001 = Reserved. | 
010= Attribute memory space. 

011 = |/O space. — 

100 = DMA (normal DMA transfer. 

101 = DMA last transaction. 

110 = Drive the value of the A22 and A23 signals on CE2 and CE1. 

111 = Reserved. 


The “DMA” encoding will generate a normal DMA transfer unless signaled as “last” by the 
on-chip DMA controller. In this case, TC(OE) or TC (WE) is asserted. The “DMA last 
transaction” encoding will generate a DMA transfer with TC(OE) or TC (WE) asserted, 
regardless of any internal indication. 


PSLOT—PCMCIA Slot Identifier 


O= Reserved. 
1 = This window defined for slot B. 


WP—Write-Protect 


0 = This window is not write-protected. 
1 = This window is write-protected. If you try to write to this window, a bus error 
(machine check interrupt) will occur. 


PV—PCMCIA Valid 


This bit indicates that the contents of the PCMCIA base register and option register pair are 
valid. 


0 = This bank is invalid. 
1 = This bank is valid 
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17.6 PCMCIA CONTROLLER TIMING EXAMPLES 
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Figure 17-3. PCMCIA Single Beat Read Cycle PRS = 0 PSST = 1 PSL = 3 PSHT = 1 
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Figure 17-4. PCMCIA Single Beat Read Cycle PRS = 0 PSST = 2 PSL = 4 PSHT = 1 
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Figure 17-5. PCMCIA Single Beat Read Cycle PRS = 0 PSST = 1 PSL = 3 PSHT = 0 
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Figure 17-6. PCMCIA Single Beat Write Cycle PRS = 2 PSST = 1 PSL = 3 PSHT = 1 
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Figure 17-7. PCMCIA Single Beat Write Cycle PRS = 3 PSST = 1 PSL = 4 PSHT =3 
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Figure 17-8. PCMCIA Single Beat Write with Wait PRS = 3 PSST = 1 PSL = 3 PSHT = 0 
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Figure 17-9. PCMCIA Single Beat Read with Wait PRS = 3 PSST = 1 PSL = 3 PSHT = 1 
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Figure 17-10. PCMCIA I/O Read PPS = 1PRS = 3 PSST = 1PSL = 2 PSHT = 0 
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SECTION 18 
LCD CONTROLLER 


The MPC823 contains an on-chip LCD controller that can be used to drive an LCD panel 
display. The integrated LCD controller shortens access time, reduces power consumption, 
and saves system board space by not using external glue logic. The LCD controller can 
interface with a variety of passive, active, dual-scan, single-scan, and smart LCD panels. 


18.1 FEATURES 


The following is a list of the LCD controller’s main features: 


Passive, Active, and Smart Panel Interfaces Are Supported 
Requires No Special Display Memory (Uses System Memory) 


One, Two, or Four Bits Per Pixel in Grayscale Mode Generates a Maximum of 16 
Grayscale Levels Using an Advanced Frame Rate Control Algorithm 


Four or Eight Bits Per Pixel in Color Mode Generates 16 or 256 Simultaneous Colors 
From 4,096 Color Patterns 


Interfaces To the LCD Panel Through a 4-, 8-, or 12-Bit Wide Parallel Output Bus 
Supports Single-Scan or Dual-Scan Screens 

Supports Many Split Display Data Modes 

Requires No CPU or Communication Processor Module Intervention 

Built-In 256 Entry Color RAM 

Programmable Wait Time Between Lines and Frames 

Programmable Panel Voltage Control for Brightness and Contrast 

Programmable Polarity For All LCD Interface Signals 

TFT/RGB Output Drives Advanced Buffer LCD Driver Chips 

Bus Performance Optimized with Burst Read DMA Cycles 
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18.1.1 LCD Technology 


A liquid crystal display (LCD) implements a low-power display technology that uses ambient 
light to display images. LCDs consist of two pieces of glass with electrodes printed on the 
inside and polarizers are used on the outside front and rear surfaces. When the LCD is off, 
no voltage is applied to the electrodes and light passes through the LCD. When it is on, 
voltage is applied to the electrodes and the liquid crystal molecules align themselves in the 
direction of the electric field. This causes the light to be blocked and out of phase with the 
polarizers, which creates a dark area on the LCD. This darkness is a function of the RMS 
voltage applied to them. This means that the polarity of the applied voltage is not important 
and that no DC bias is allowed. A typical monochrome LCD module is illustrated in 

Figure 18-1 below. | | 
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Figure 18-1. LCD Panel 


The Y drivers apply high voltage to one row at a time. At the same time, the X drivers 
connect the dark pixels to the opposing voltage and bright pixels to the same voltage as the 
row. The value of each pixel is shifted by the shift register and latched when the whole row 
is ready. While one row is being refreshed, the next row is being shifted in and each row is 
refreshed at a rate inverse to the number of rows. If the number of rows is large, then the 
refresh rate might become too small. When this occurs, the panel is divided into two sections 
(upper and lower). Then the X shift register, which is twice as long, works at twice the speed 
to refresh two columns at the same time (one column in the upper section and one in the 
lower section). The X shift register can be loaded 1, 2, 4, or 8 bits per shift. 
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The time it takes to refresh a row is called the duty cycle. In a simple refresh policy, one row 
is refreshed at a time. However, this creates large voltage spikes on the LCD electrodes. 
Another technique, called active addressing, refreshes groups of rows and smoothes the 
applied voltage that each pixel receives over approximately half a frame cycle. This 
significantly improves the contrast and other characteristics of a simple LCD display. The 
drawback of active addressing is that it is fairly complex and requires that you have a 
dedicated chip to perform it on. This chip holds a large display buffer (typically equivalent to 
a quarter of a VGA display per circuit). The active addressing algorithm is done on entire 
columns and it usually fits in the LCD display path and appears to the system as a thin film 
transistor (TFT) interface. 


It is important to avoid long-term DC bias in the voltages applied to the LCD screen because 
it causes defects in the polarization as well as raindrop-like patterns (raindrop effect) to 
appear on the display. To overcome this problem the controller should change the field 
polarity every few frames. 


18.1.2 Types of LCD Interfaces 


Basic LCD panels require a clock, one or more data input lines, and horizontal and vertical 
syncs. These signals are usually provided by an LCD controller that includes a frame buffer 
RAM for display memory. An example of a complete LCD subsystem is illustrated in 
Figure 18-2. 7 
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Figure 18-2. LCD Subsystem 
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18.1.2.1 PASSIVE LCD INTERFACE. A passive LCD panel interface uses X and Y shift 
registers to operate. The X shift register is used to display a column and the Y shift register 
is used to display a row. The LCD controller fills the shift register, provides naming; and 
reverses the display ony from frame-to- frame or line-to-line. 






PASSIVE SINGLE-SCAN 
PANEL 





PASSIVE DUAL-SCAN - 
PANEL 





FRAME 
UD[0:x] 
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x = [3, 7] 





Figure 18-3. Passive Interfaces | 


@® 


A passive LCD interface consists of several parallel data bits that are shifted into the X shift 
register by the shift clock. After the shift register is full, a latch signal transfers the pixels from 
the shift register to driver latches and moves the Y pointer down one line. At this point, the 
shift operation continues to the next line and after all the lines are scanned, the frame signal 
moves the Y pointer to the beginning of the frame. The LCD controller also accesses the 
frame buffer. The panel can be single- or dual-scan and the dual-scan function is 
accomplished by splitting the Y dimension. For single-scan panels, the LCD controller only 
has one buffer. For dual-scan panels, the LCD controller must have one upper and one 
lower frame buffer. In most LCD panels, you need control to kill any DC biases that build up 
during normal operation. A signal that inverts the polarity of the voltages is presented to the 
LCD panel. Usually, this signal toggles every few frames (1-20). 
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18.1.2.2 ACTIVE LCD INTERFACE. An active LCD panel interface is referred to as a thin 
film transistor (TFT) interface. It provides a high-performance LCD panel that looks more like 
a digital RGB or monochrome video signal that has several data bits in parallel. The shift 
clock is also present. Latch and frame signals are called horizontal sync and vertical sync 
and have special timing. There is also a special signal called output enable that 
blanks/enables data, but does not affect the clock. For color displays, the MPC823 supports 
a 12-bit (four bits per basic color) data bus. For example, an 8-bit pixel data fetched from the 
frame buffer is passed through a 256 x 12 memory that selects one out of 256 colors. 






VSYNC 
R[0:x] 
G[0:x] 
B[0:x] 
x = 2, 3, 4] 


Figure 18-4. Active (TFT) interface 
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18.1.2.3 SMART PANEL LCD INTERFACE. In asmart panel interface, the whole memory 
display buffer resides on the panel, which is directly connected to the system bus. Also, the 
CPU accesses the display memory directly, so you do not need a controller. 


18.2 THE MPC823 LCD CONTROLLER 


The MPC823 LCD controller is initialized by the core, which provides the frame. buffer 
address, operational modes, and various configuration bits that the LCD controller needs to 
operate. After it is enabled, the LCD controller requests the DMA to fetch the frame buffer 
data. The frame buffer is always organized in rows and columns. Depending on the interface 
you are using, the data is then interpreted for grayness or color and frame format. The data 
is then packed according to the model you have chosen. If you are using a split panel 
display, you need to initialize two buffers—one for each panel display. The LCD controller 
uses continuous DMA to feed the display. Figure 18-5 illustrates a typical MPC823 LCD 
system. 
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Figure 18-5. The MPC823 LCD System 
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The MPC823 LCD controller is a module that is separate from the core and communication 
processor module. It uses the internal DMA, bus, and system interface unit to access frame 
buffer memory. The LCD controller has dedicated registers that provide timing generation 
to control the panel. It also has two FIFOs that interface to color RAM, which provides pixel 
generation and a data path to the panel. The LCD controller block diagram is illustrated in 


Figure 18-6. 
REGISTERS TIMING GENERATION 
5 DMA ADDRESS 
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INTERFACE 
COLOR 
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Figure 18-6. LCD Controller Block Diagram 


18-6 MPC823 USER’S MANUAL MOTOROLA 


LCD Controller 


18.3 LCD CONTROLLER OPERATION 


The LCD controller uses the system interface unit to communicate with the core and external 
system. It has its own DMA functionality to fetch display memory into the FIFOs for pixel 
generation. The LCDCLK signal is derived from the SPLL output (VCOOUT) and is fed to 
the timing generator for vertical, horizontal, and frame timing. The register set is used to 
program the timing parameters for an LCD panel. Figure 18-7 illustrates the various 
modules of the LCD controller. 
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Figure 18-7. LCD Functional Module 
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After reset, the LCD controller is disabled (PON=0) in the LCD configuration and control 
register (LCCR). To operate the LCD controller, you should program the LCD registers and 
set the PON bit. When enabled, the FIFOs ask the DMA controller to fill them using burst 
read memory cycles. When data is available in the FIFOs, it is used to index into the color 
RAM to produce a grayscale or color pattern. This pattern is then shifted out by the 
horizontal control block, which generates timing for each pixel on a line, including the wait 


between lines (VVDL). IIe vertical control DIOCK Counts in Ic numbei Of lines anda provides a 
wait between frames (WBF) timing. 


The LCD controller consists of eight main blocks: 


e FIFOs 
¢ Pixel generation 
Horizontal control 


@ 


Vertical control 
¢ Frame control 
¢ DMA control 

¢ Timing control 
¢ LCD interface 


18.3.1 FIFO Control 


There are two FIFOs in the LCD controller that are concatenated for single-scan displays 
and used separately for dual-scan displays. Each FIFO has the capacity to hold 12 32-bit 
words. When the FIFO can accept a burst, it requests a DMA controller access, which 
guarantees no FIFO overflow. When the FIFO is empty before frame completion and the 
DMA cannot provide data because of heavy bus loading, a FIFO underrun condition occurs. 
If such a condition occurs, the display image may flicker, tear, or shift. In order to recover, 
you must restart the LCD controller. It is your responsibility to make sure the LCD controller 
has sufficient bus bandwidth to avoid underrun conditions. When the data is available in the 
FIFOs, the frame controller initiates frame processing. 
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18.3.2 Pixel Generation 


The pixel generation block retrieves data from the FIFOs to generate a grayscale or color 
pattern by indexing into the color RAM area of dual-port RAM. For single-scan displays, data 
is fetched serially from both FIFOs. For dual-scan displays, data is fetched alternatively from 
both FIFOs. 


18.3.2.1 GRAYSCALE. For single-bit grayscale (monochrome), each pixel is represented 
by a single bit in the frame buffer, also called the display buffer. A zero signifies pixel off and 
a one signifies pixel on. For fours bits per pixel, one pixel requires four bits in the memory 
that are packed together with the next four bits for the next pixel. The LCD controller can 
generate a maximum of 16 grayscale levels whereby each pixel is represented by four bits 
in the frame buffer. Grayscale is generated by controlling the rate in which each pixel is 
turned off and on. This method is referred to as frame rate control (FRC). Turning the pixels 
on and off under frame rate control may result in a low frequency pixel refresh rate to a given 
pixel. This refresh rate may cause image flickering when the same gray level is found in 
adjacent pixels. However, the MPC823-implemented FRC algorithm should minimize this 
flicker. 


When one bit per pixel is defined, the color RAM table is used as a transparent translation 
to pass the RAM data through the LCD panel interface. When you are using two bits per 
pixel, the 2-bit code is indexed into the color RAM to one of four entries. Each of these four 
entries can be one of 16 possible gray level codes. These four entries are then used to 
determine the FRC value for that pixel. With four bits per pixel, the 4- bit code is used to 
index one of 16 entries in the color RAM. The 4-bit code from the color RAM is then used to 
determine one of the 16 shades generated by frame rate control. Figure 18-8 illustrates 
grayscale generation. 
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Figure 18-8. Grayscale Generation 
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18.3.2.2 COLOR. Each color pixel is represented as a 4- or 8-bit code in the frame buffer. 
Using the color RAM, the pixel code is mapped to a 12-bit red/green/blue (RGB) code, which 
allows you to select one of 4,096 colors. For passive color displays, the frame rate control 
algorithm processes each color to generate the required amount of intensity, as derived from 
the nine bits (maximum) of RGB information in the color RAM. For active color displays, 
12 bits (4 bits per color) are output directly onto the LCD data bus. Figure 18-9 illustrates 
color generation. Notice that the LCD data bus is shown with MSB on the left and LSB on 
the right. The LCD_A, LCD_B, and LCD_C bits are the least-significant bits of each color., 
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Figure 18-9. Color Generation 
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18.3.3 Horizontal Control 


The horizontal control block pone the pixel count for one line and any additional wait 
between lines. It also enables the pixel generation block by passing a signal from the vertical 
control block to each line. Upon completion of the wait between lines, as indicated in the 
WBL field of the LCHCR, it signals the vertical control block and activates the LOAD/HSYNC 
signal to indicate the start of the next line. | . 


18.3.4 Vertical Control 


The vertical control block counts the lines and signals the horizontal control block. Upon 
completion of the wait between frames, as indicated in the WBF field in the LCVCR,, it 
signals the frame control block and activates the FRAME/VSYNC signal to indicate the start 
of the next frame. 


18.3.5 | Frame Control 


The frame control block initializes all counters, starts the DMA, and provides signaling to the 
vertical control block. The frame control block generates an end of frame signal indicator that 
can be used to generate an interrupt. The end of frame interrupt can be enabled by setting 
the IEN bit in the LCCR. 


18.3.6 DMA Control 


The DMA control block handles all data transfers to and from the FIFOs and keeps them 
filled. At the appropriate time, each FIFO is filled by the DMA control block in 16-byte 
transfers. Your frame buffer address should be 16-byte aligned. When the LCD controller is 
initiated at reset or after an underrun condition, LCD data transfers to the panel start after 
five DMA read burst accesses to display memory have filled the FIFOs. See 

Section 16.5.1 SDMA Bus Arbitration and Transfers for proper arbitration configuration 
between the LCD controller DMA and the SDMA. 
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18.3.7 Timing Control 


The LCD controller is clocked by the LCDCLK signal that the system interface unit generates 
by dividing the system clock. The LCDCLK signal is used to convert frame data to pixel 
format. The division factor depends on the type of display you are using. You should 
program LCDCLK using the following table. For information on the system clock and reset 
control register, refer to Section 5 Clocks and Power Control. 


Table 18-1. LCDCLK Programming 


LCD PANEL TYPE/DATA WIDTH 
SINGLE-SCAN DUAL-SCAN 
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BITS PER PIXEL/PANEL TYPE 






4- or 8-Bit Color Passive 
4- or 8-Bit Color Active (TFT) F 


NOTE: F denotes the LCD panel clock frequency. 
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18.3.8 Contrast and Brightness Control 7 | 


lf you do not use frame rate control to handle contrast and brightness, then you will need 
external circuitry to give you more control for those panel inputs. Refer to your panel 
specifications to find out what you need for your panel. 


18.3.9 The LCD Interface 


The LCD interface provides drivers for the data, clock, and control signals to the LCD 
display. It consists of 12 data bits (LD[0:8], LCD_A, LCD_B, and LCD_C), a data clock 
(SHIFT/CLK), vertical and horizontal control (FRAME/VSYNC and LOAD/HSYNC), and 
panel control (LCD_AC/LOE). You can program the polarity of each of these signals. The 
LCD interface can be configured to support a variety of panels—single-scan, dual-scan, 
color, monochrome, passive, and active. 
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18.3.9.1 SINGLE-SCAN AND DUAL-SCAN PANELS. Some LCD panels split the display 
area into two horizontal halves that are scanned at the same time so that two lines are 
shifted and displayed simultaneously in each half. In this case, half of the data bus is used 
to drive the upper half of the screen and the other half is used to drive the lower half. 
Figure 18-10 illustrates single-scan and dual-scan LCD panels. 
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Figure 18-10. Single-Scan and Dual-Scan LCD Panels 





18.3.9.2 PASSIVE INTERFACE. Passive LCD interfaces use the following signals. These 
signals have a programmable polarity. T.,, is the cycle time of the LCD clock (SHIFT/CLK). 
Tuelay iS a circuit delay that is specified in Section 22 Electrical Characteristics. 


e SHIFT/CLK—On the asserted edge of SHIFT, data is latched into the X shift register. 


e FRAME/VSYNC—The FRAME signal initiates the frame by putting the Y pointer at the 
first row. 


LOAD/HSYNC—The LOAD signal transfers the contents of the shift register into the 
drive latches. 


e LCD_AC/LOE—The LCD alternating current seed ages every few frames to pully 
any DC voltage. The toggle rate is programmable. 


e LD—The width of this data bus is configured to 4 or 8 bits. 


A general-purpose I/O can be used to output an integrated signal or pulse-width modulation 
(PWM) waveform and its duty cycle controls the RMS value of the voltage to the panel. The 
PWM signal is generated by one of the communication processor module timers. Refer to 
Section 16.2.7 RISC Microcontroller Commands for more details. 
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Figure 18-11. Passive Interface Timing Diagram 
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18.3.9.3 ACTIVE INTERFACE. Active (TFT) interfaces use the following signals. These 
signals have a programmable polarity. T,,, is the cycle time of the LCD clock (SHIFT/CLK). 
Tuelay iS a circuit delay that is specified in Section 22 Electrical Characteristics. In 
Figure 18-12, the reference to 1-16 lines signifies that the time period depends on how the 
VPW field in the LCVCR is programmed. The reference to 0-1,023 lines signifies that the 
time period varies between 0 and 1,023 scan lines (WBF field in the LCVCR). 


SHIFT/CLK—When the LCD output enable signal is valid, data is latched on the 
asserted edge of CLK. 


FRAME/VSYNC—This vertical sync signal initiates a new frame. 
LOAD/HSYNC—This horizontal sync signal initiates a new line. 


LCD_AC/LOE—When the LCD output enable signal is valid it enables data to be shifted 
into the display. When it is disabled, the data is invalid and no data is transferred. 


LD—The LCD data bus represents 4-, 8-, or 12-bit data. For monochrome displays, 4- 
or 8-bit data is the same as passive interfaces and 12-bit data is used for color displays. 


Use the following formulas to calculate the HSYNC and VSYNC cycles using the 
user-programmable parameters that are located in the LCD control registers. 


VSYNC = (HSYNC x L) +WBF 

HSYNC = SHIFT/CLK x (P + LCDBW +12 + TWBL) 
SHIFT/CLK = LCDCLK x F | 
LCDCLK = VCOOUT x LCD_div_factor (programmed) 


Where: 


L = Number of lines in panel (+2 for dual-scan displays and +VPW in LCVCR for active). 
WBF = Number of waits between frames. 

P = Number of pixels per line in panel (x2 for dual-scan displays). 

LCDBW = LCD bus width (4- or 8-bit for passive displays and 1 for active). 

TWBL = Total number of waits between lines. 

VCOOUT = SPLL output frequency. 

LCD_div_factor = LCD_div_factor is programmed in the SCCR (DFLCD x DFALCD). 

F = Inner rate factor that depends on your configuration: 


3: Fora four bits per pixel color ponene display with an 8- bit LCD data bus width 
single-scan. 


2: Fora four bits per pixel color passive display with an 8-bit LCD data bus width 
dual-scan or with a 4-bit LCD data bus width single-scan. 


1: For all other configurations. 
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Figure 18-12. Active Interface Timing Diagram 


MOTOROLA MPC823 USER’S MANUAL 18-17 


QO. 
Ses 





LCD Controller 


18.3.9.4 ANALOG INTERFACE. The MPC823 has a digital interface, so you will need a 
DAC to connect the MPC823 to an analog panel. 


18.3.10 System Considerations 


When you are designing a system with the LCD controller, you should monitor the bus 
bandwidth used by the LCD subsystem and the maximum allowable bus latency. The 
configuration below uses the following narameters: 


GCLK2/CLKOUT—System clock frequency 

e BNUM—Number of bursts per frame 

e FRR—Frame refresh rate 

e BPIX—Number of bits per pixel 

e COL—Number of display columns 

e ROW—Number of display rows 

e MB—Number of system clocks per memory burst 


You must configure the parallel to serial clock ratio between the system clock and the LCD 
serial data clock. The following example contains typical ey characteristics for a full 
VGA panel (640 x 480) calculation: 


¢ 640 x 480 = 307,200 pixels per screen 
e (307,200 pixels per screen) x 4 bits per pixel = 1.228Mb per screen = 150Kb per screen 
¢ 70Hz x 150Kb = 10.5Mb/s 


¢ 70HZz is 14.3ms per frame: 14.3ms/307,200 pixels clocked 4 bits at a time = 186ns 
(approximately 5MHz) serial clock to the LCD drivers 


The display serial clock is slightly faster than 5MHz because of the panel overhead. In most 
VGA displays, however, an 8-bit LCD serial data (dual-scan passive panel) is used and the 
display frequency is 3.76MHz. The CLKOUT to LCDCLK ratio should be between 4:1 and 
5:1 for optimum system operation. 


18.3.10.1 BUS BANDWIDTH. The bus bandwidth that the LCD controller uses depends on 
the display parameters (size, refresh rate), the memory system (number of clocks per burst), 
and the system clock frequency. | 
COL x ROW x BPIX 

BNUM = So apg eos 


BNUM x FRR x MB és 
Bus Band Width = camaecer 7.) i aaa x 100% 
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18.3.10.1.1 Example. The following example shows a monochrome full VGA (640x480) 
passive display, single-scan, 4-bit panel data bus. The LCD controller will provide 8-bit per 
pixel coding with a refresh rate of 80Hz. In this example, assume a display memory cycle 
burst timing of (2, 1, 1, 1) for a total of five cycles per burst. 

SCLK = 25MHz 

FRR = 90Hz 

MB=5 

BPIX = 8 

COL = 640 

ROW = 480 

BNUM = (COL x ROW x BPIX) + 128 

Bus Band Width = (BNUM x FRR x MB) + SCLK 


Bus Band Width = 2600x90%5 . i999, - 17% 
25x10 
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18.3.10.2 BUS LATENCY. The maximum bus latency allowed in the system is given by: 


MB x SCLK 
BNUMxFRR 


D von 





Max Latency = 


Typical example using the same data from above: 


5x 25x10° 


Max Latency = 9600 x90 


= 145 System Clocks 
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18.4 REGISTER MODEL 


18.4.1 LCD Controller Configuration Register 


The 32-bit, memory mapped, read/write LCD controller configuration register (LCCR) holds 
the mode and configuration parameters that you can use to operate your LCD panel. 


(IMMR & OxFFFFO000) + 0x842 





BNUM—Number of Bursts 
This field contains the number of burst cycles required for one refresh cycle. 


EIEN—Exception Interrupt Enable 


QO = The underrun or bus error interrupt is disabled. 
1 = The underrun or bus error interrupt is enabled. 


lEN—Interrupt Enable 


O0= The end-of-frame interrupt is disabled. 
1 = The end-of-frame interrupt is enabled. 


IRQL—Interrupt Request Level 

This field contains the priority request level of the LCD controller’s interrupt that is sent to 
the system interface unit. Refer to Section 12.3.3 Programming the Interrupt Controller 
for more information. This will generate an interrupt request level with a vector in the SIVEC 
register if enabled with the SIMASK register. Both EOF and the exception interrupts use the 
same request level. 


CLKP—Clock Polarity 


O= The SHIFT/CLK pin polarity is active high. 
1 = The SHIFT/CLK pin polarity is active low. 


18-20 --MPC823 USER’S MANUAL MOTOROLA 


LCD Controller 


OEP—Output Enable Polarity 
0= The LCD_AC/LOE pin polarity is active high. 
1 = The LCD_AC/LOE pin polarity is active low. 


HSP—Horizontal Sync Polarity 


0= The LOAD/HSYNC pin polarity is active high. 
1 = The LOAD/HSYNC pin polarity is active low. 


VSP—Vertical Sync Polarity 


O= The FRAME/VSYNC pin polarity is active high. 
1 = The FRAME/VSYNC pin polarity is active low. 


DP—Data Polarity 


0= The LCD data (LD) pin polarity is active high. 
1 = The LCD data (LD) pin polarity is active low. 


BPIX—Bits Per Pixel 
This field indicates the number of bits that represent one pixel in display memory. 
00 = One bit per pixel. 
01 = Two bits per pixel. 
10 = Four bits per pixel. 
11 = Eight bits per pixel. 
LBW—LCD Bus Width 


This field indicates the number of data bits that are output for every SHIFT/CLK. It is omy 
valid for monochrome displays. For TFT displays, see the TFT bit below. 


O = Four bits per clock. 
1 = Eight bits per clock. 


SPLT—Split Display Mode 


0= The display is dual-scan (one row is displayed at a tified 
1 = The display is single-scan (two rows are displayed at a time). 


CLOR—Color Display 


O0= TheLCD panelisa monochrome sisciay. 
1 = The LCD panel is a color display. 


TFI—TFT Display 
When this bit is set, 12 bits of RGB (4 bits per color) data are sfovided on the LD data bus. 


0 = The LCD panel is a passive display. 
1 = The LCD panel is an active (TFT) display. 
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PON—Panel On 


0 = The LCD controller operation is disabled. 
1 = The LCD controller operation is enabled. 


18.4.2 LCD Horizontal Control Register 


The 32- bit, memory-mapped, read/write LCD horizontal control register (L_CHCR) holds the 
al pixel resolution ana oiner coniiguration parameters. 





(IMMR & OxFFFFO000) + 0x846 _ 


Bits O-6—Reserved 
These bits are reserved and should be set to 0. 


BO—Byte Order 


O= The DEC/Intel convention is used for byte ordering (swapped operation) and is 
also called little-endian byte ordering. The transmission order of bytes within a 
buffer word is reversed in comparison to the Motorola mode. This mode is 
supported only for 32-bit port size memory. Motorola byte ordering (normal 
operation) is also called big-endian byte ordering. As data is transmitted onto the 
serial line from the data buffer, the most-significant byte of the buffer word contains 
data to be transmitted earlier than the least-significant byte of the same buffer 
word. 

1 = PowerPC little-endian byte ordering. As data is transmitted onto the serial line from 
the data buffer, the least-significant byte of the buffer double-word contains data to 
be transmitted earlier than the most-significant byte of the same buffer 
double-word. 


AT—Address Type 


This field contains values that you want to appear on the AT pins when the associated 
SDMA channel accesses memory. ATO is always driven to 1. Refer to 
Section 13.4.7.3.4 Address Space Attributes for address type descriptions. 
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HPC—Horizontal Pixel Count 


This field specifies the number of pixels per line adjusted by panel type and bits per pixel. 
Use Table 18-2 to program the value for this field. 


Table 18-2. Horizontal Pixel Count Programming 





LCD PANEL TYPE/DATA WIDTH 








SINGLE-SCAN DUAL-SCAN 


12 BIT 8-BIT 4-BIT 8-BIT 4-BIT 
{-Bit Monochrome, 2-/4-Bit Grayscale po 18*H | 1/4*H 1/4*H 1/2*H 
4-/8-Bit Color Passive po 38*H | 3/4*H | 3/4*H 


BITS PER PIXEL/PANEL TYPE 
















NOTE: H indicates the number of pixels per line. 


WBL—Wait Between Lines 


To achieve the best display quality, this field can be used as an adjustable parameter to 
modify the resultant image. This field represents the wait period between lines, which are 
measured in SHIFT/CLK cycles. The total number of wait cycles are WBL+N, where: 


fa 
uu 
wl 
onl 
oO 
oc 
= 
= 
O 
O 
‘an 
© 
al 





N = 7 in configurations in which the panel type is a passive monochrome with a 4 bit 
data bus configured with two or four bits per pixel. BPIX = 01 or 10, CLOR = 0, 
TFT = 0, and LBW = 0 as defined in the LCCR. 


N = 5 for all other configurations. 


18.4.3 LCD Vertical Configuration Register 


The 32-bit, memory-mapped, read/write LCD vertical control register (_CVCR) holds the 
panel vertical pixel resolution and other configuration parameters. 


LCVCR 









VPW RESERVED LCD_AC VPC 
(IMMR & OxFFFF0000) + 0x848 


VPC 


(IMMR & OxFFFFO000) + 0x84A 
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VPW—Vertical Sync Pulse Width (with active (TFT) panels only) 


This field controls the width of the active FRAME/VSYNC signal with its value represented 
in line units. Programming this field to n causes FRAME/VSYNC to be active for nlines. This 
field is only valid for TFT displays and should be cleared for all others. 


Bits 4—6 and 21—Reserved 


These hite ara rasarvad and should be set io 0. 


~ wrth VAP ty PI VA CAL! 


LCD_AC—LCD AC Timing 
This field specifies the number of frames that are displayed before the LCD_AC/LOE pin is 
toggled. 


VPC—Vertical Pixel Count 


This field specifies the number of lines per frame. Use Table 18-3 to program the value in 
this field. 


@ 


Table 18-3. Vertical Pixel Count Programming 


LCD PANEL TYPE/DATA WIDTH 
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BITS PER PIXEL/PANEL TYPE SINGLE-SCAN DUAL-SCAN 


12-BIT 8-BIT 4-BIT 8-BIT 4-BIT 





1-Bit Monochrome, 2-/4-Bit Grayscale 


ee ee ee 
4-/8-Bit Color Passive fF — | vi [ov | V/2 
a ae ae 


4-/8-Bit Color Active (TFT) 





NOTE: V indicates the total number of lines on the panel. 


WBF—Wait Between Frames | 
This field represents the wait period between frames, which is measured in lines. 
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18.4.4 LCD Frame Buffer A Start Address Register 


The 32-bit LCD frame buffer A start address (LCFAA) register contains the start address of 
the frame buffer data that you want sent to your LCD panel. FIFO A is the destination for 
your frame buffer data. For single-scan panels, FIFO A concatenated with FIFO B is used 
to transfer data, so only the LCFAA register needs to be loaded. The DMA controller uses 
the buffer start address to initiate data transfers from display memory, which can be system 
memory or a dedicated display memory block. Because all LCD controller DMA bursts must 
be 16-byte aligned, the four least-significant bits of the address are not used. This register 
is read by the LCD controller at the start of each frame. Therefore, changing this register will 
not take effect until the WBF bit expires. 


LCFAA 
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(IMMR & OxFFFFO000) + 0x852 


NOTE: X - “Don’t Care” and — = Undefined. 


FAA—FIFO A Address 


This field designates the start address in display or system memory where LCD panel data 
resides. 
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18.4.5 LCD Frame Buffer B Start Address Register 


The 32-bit LCD frame buffer B start address (LCFBA) register contains the start address of 
the frame buffer data that you want to send to your LCD dual-scan panel (lower half). FIFO 
B is is the destination for your frame buffer data to be passed to the lower half of the panel. 
Notice that for single-scan panels FIFO B is concatenated with FIFO A to transfer data, so 
only the LCFAA register needs to be loaded. However, for dual-scan panels, the LCFBA 
register musi be set. For these duai-scan paneis, the DiVA controiler uses the buffer B start 
address to initiate data transfers from display memory (system memory or a dedicated 
display memory block) to FIFO B. Because all LCD controller DMA bursts must be 16-byte 
aligned, the four least-significant bits of the address are not used. This register is read by 
the LCD controller at the start of each frame. Therefore, changing this register will not take 
effect until the WBF bit expires. 


LCFBA 










(IMMR & OxFFFFO000) + 0x854 








IMMR & OxFFFFO000 + 0x856 


NOTE: X - “Don’t Care” and — = Undefined. 


FBA—FIFO B Address 


This field designates the start address in display or system memory where the LCD panel 
data resides. The data retrieved is for the lower half of a dual-scan panel and passes 
through FIFO B. 
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18.4.6 LCD Status Register 


The 8-bit memory-mapped LCD status register (LCSR) is used to report certain events to 

the core. When an event is recognized, the LCD controller sets its corresponding bit in this 
register, regardless of the corresponding enable bit, which is located in the LCCR. A bit is 
cleared by writing a 1 (writing a 0 has no effect) and more than one bit can be cleared ata 
time. 


LCSR 







PRESERVED OOS ~ | BERR | UN | EOF — 
a ee ee ee 
aS eR ee 


Bits O-4—Reserved 
These bits are reserved and should be set to 0. 





BERR—Bus Error 


This status bit is set if a display memory read cycle by the LCD controller FIFO is abnormally 
terminated. If the EIEN bit is set in the LCCR, then an interrupt is generated to the system 
interface unit at the level specified in the IRQL field of LCCR. 


UN—Underrun 


When this bit is set, it indicates that a FIFO underrun condition has been detected. An 
underrun condition occurs when the LCD controller is empty before a frame is completed. If 
the EIEN bit is set in the LCCR, then an interrupt is generated to the system interface unit 
at the level specified in the IRQL field of LCCR. 


EOF—End Of Frame 


This status bit is set when a frame is completed and if the IEN bit in the LCCR is enabled. 
Then an interrupt is generated to the system interface unit at the level specified in the IRQL 
field of LCCR. 
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18.4.7 Color RAM Operation Modes 


The color RAM contains 256 entries that are each 16 bits wide. It is located in the dual-port 
RAM and is not initialized at reset. Your LCD panel and its required mode will dictate how 
the display or system memory and the color RAM is configured. 


“==ay = ss Note: = Before programming the color RAM, you mu 


si program ine LCCR to ine specific 
data coding, number of bits per pixel, color or monochrome, e 


tc. 


18.4.7.1 ONE BIT PER PIXEL MONOCHROME MODE. When you are using this mode 
(TFT=0, BPIX=00, and CLOR=0), configure color RAM using the following pattern. You 
should program the first 16 entries of the color RAM to be transparent. 


(IMMR & OxFFFF0000) + (DPR) 0xEO0—0xE1F 





NOTE: —= Undeined. 


Bits O-11—Reserved 
These bits are reserved and should be set to 0. 
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GLC—Grayscale Level Code (Monochrome Display) 


This field is a 4-bit code that represents the grayscale level. It must be programmed to the 
value of the entry number. For entry 0 GLC = 0000, for entry 1 GLC = 0001, and for entry 2 
GLC = 0010 as shown below. 


GLC 


COCO UEC ECEREEEE 
PEROUCUGRECECERE 
e/a oreo e) aa hg ag 
OOO OUR C ECE CREE 
9 [00/00 [o}o fofo oo} 0], 0}0 
DUGG IDB OR RCE REEY 
DOGG IOQOR RRC REEE 
SPCR Reece 
EEEOUROCERECEEED 


















LCD CONTROLLER 






@ 










qqgg20a0 00000000 


Figure 18-13. Color RAM Transparent Translation for One-Bit Per Pixel Mode 
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18.4.7.2 TWO BITS PER PIXEL GRAYSCALE MODE. In two bits per pixel grayscale 
mode, the LCD controller provides four possible shades to be loaded into each pixel of the 
LCD panel. The two bits of data are provided by each display memory word that is accessed 
by the DMA controller. This value will then index into the color RAM at addresses 1, 3, 5, 
and 7. You can provide any four of 16 possible shades by loading the color RAM addresses 
shown below. 


RESERVED GLCB GLCA 





(IMMR & OxFFFFO000) + (DPR) OxEO00O—0xE07 
NOTE: — = Undefined. 


Bits O-—7—Reserved | 
These bits are reserved and should be set to 0. 


GLCA/GLCB—Grayscale Level Code A and B 


This field is a 4-bit code that represents the grayscale level for a given pixel code. GLCA and 
GLCB should be programmed to the same value. The 4-bit code should be programmed in 
one of the following ways: 


e Program address 1 of the color RAM with the grayscale level code that corresponds to 
pixel code 00 that was retrieved from display memory. 


e Program address 3 of the color RAM with the grayscale level code that corresponds to 
pixel code 01 that was retrieved from display memory. 


¢ Program address 5 of the color RAM with the grayscale level code that corresponds to 
pixel code 10 that was retrieved from display memory. 


e Program address 7 of the color RAM with the grayscale level code that corresponds to 
pixel code 11 that was retrieved from display memory. 


GLCB GLCA 





Figure 18-14. Color RAM Entries for Two Bits Per Pixel Mode 
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18.4.7.3 FOUR BITS PER PIXEL GRAYSCALE MODE. In four bits per pixel grayscale 
mode, the LCD controller provides 16 possible shades to be loaded into each pixel of the 
LCD panel. The four bits of data are provided by each display memory word that is accessed 
by the DMA controller. This value will then index into the first 16 odd addresses of the color 
RAM. You can provide any of the 16 possible shades by loading the color RAM addresses 
shown below. See Figure 18-8 for more information. 


ee SS 
RESERVED | GLCB GLCA 


(IMMR &0xFFFFO000) + (DPR) 0xE00O—OxFFF 





NOTE: — = Undefined. 


Bits O-7—Reserved 
These bits are reserved and should be set to 0. 
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GLCA/GLCB—Grayscale Level Code A and B 


This field is a 4-bit code that represents any one of 16 possible grayscale levels for a given 
pixel code. This grayscale level is then used to represent the appropriate shade for a given 
pixel and is passed to the appropriate panel bit. GLCA and GLCB should be programmed 
to the same value. The color RAM to be programmed is shown below. 





® : 
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Figure 18-15. Color RAM Entries for Four Bits Per Pixel (Grayscale) 
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18.4.7.4 PASSIVE FOUR AND EIGHT BITS PER PIXEL COLOR MODE. This mode 
operates the same way for four or eight bits per pixel and the color RAM is loaded similarly. 
You provide a 4- or 8- bit data word that the DMA controller retrieves from display memory 
and that value is indexed into the color RAM as shown below. For four bit per pixel mode, 
you can choose 1 of 16 colors from the 4,096 possible colors. For eight bits per pixel mode, 
you can choose one of 256 colors from the 4,096 possible colors. See Figure 18-9 for more 
information. 









(MMR & OXFFFF0000) + (DPR) 0xEOO—OxE1F (4-BIT) OR 0xEOO—OxFFF (8-BIT) 






NOTE: — = Undefined. 


Bits O-3—Reserved 
These bits are reserved and should be set to 0. 


R—Red Level 


This field is a 4-bit code that represents the red color level. The frame rate control dictates 
when this color pixel is on or off. 


G—Green Level 


This field is a 4-bit code that represents the green color level. The frame rate control dictates 
when this color pixel is on or off. 


B—Blue Level. 


This field is a 4-bit code that eases the blue color level. The frame rate control dictates 
when this color pixel is on or off. 
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18.4.7.5 ACTIVE FOUR AND EIGHT BITS PER PIXEL COLOR MODE. This mode 
operates the same way for four or eight bits per pixel and the color RAM is loaded similarly. 
You provide a 4- or 8- bit data word that the DMA controller retrieves from display memory 
and that value is indexed into the color RAM as shown below. For four bits per pixel mode, 
you can choose 1 of 16 out of a total of 4,096 possible colors. For eight bits per pixel mode, 
you can choose one of 256 out of the 4,096 possible colors. See Figure 18-9 for more 
information. For active (TFT) panels, each bit of data for each red, green, or blue value read 
from the color RAM is passed directly to the LCD data bus. These bits follow a particular 
sequence—LDO (MSB), LD1, LD2, LCD_A, LD3, LD4, LD5, LCD_B, LD6, LD7, LD8, and 
LCD_C (LSB). | | 


RESERVED 


a a Ee EE 


(IMMR & OxFFFFO000) + (DPR) 0xEQO—OxE1F (4-BIT) OR 0xEQO—OxFFF (8-BIT) 
NOTE: — = Undefined. — 





Bits 0-3, 7, 11, and 15—Reserved 
These bits are reserved and should be set to 0. 


R—Red Level 


This field is a 4-bit code that represents the red color level and is passed directly to the LCD 
interface. | | | 


G—Green Level 


This field is a 4-bit code that represents the green color level and is passed directly to the 
LCD interface , 


B—Blue Level 


This field is a 4-bit code that represents the blue color level and is passed directly to the LCD 
interface 
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18.4.8 LCD Panel Connection Examples 


Some panels connect differently than the MPC823. These panels are shown as examples 
in Table 18-4 and they may or may not be currently available. 


Table 18-4. LCD Panel Connection 


DISPLAY TYPES 




































MPC823 SIGNAL SHARP LM4801F SHARP HITACHI SHARP 
(PORT PIN) PASSIVE LM64Ps39_ =| LMG7211URFR La10D131 
MONOCHROME PASSIVE PASSIVE COLOR 
MONOCHROME | MONOCHROME | MONOCHROME ACTIVE 






DUAL-SCAN 


CK-P[10] CP2-P[3] CP2-P[3] CL2-P[3] CP2-P [10] CK-P[10] 
LOAD/HSYNC (PD4) | HSYNC-P{[6] CP1-P[2] CP1-P[2] CL1-P[2] HSYNC-P[6] 






SHIFT/CLK (PD3) 





FRAME/VSYNC (PD5) | VSYNC-P[4] S-P [1] S-P[1] FRAME-P[1] S-P [12] VSYNC-P[4] 













= 
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The MPC823 contains an on-chip video controller that can be used to drive a digital TFT 
LCD panel or an analog NTSC/PAL display (which needs an external video encoder). It uses | 
the same I/O pins as the LCD controller, which means you can only be using one or the other 

at a time. The video controller has features that give you more flexibility when preparing data 

for a video display. 


The video controller uses a frame buffer, also called a display buffer, that is stored in system 
memory. The data in the display buffer represents pixel components (bytes), whether it is 
RGB or YC,C,. You are responsible for preprocessing data as it is stored in the display 
buffer. The video controller uses a dedicated DMA channel to read the data from the display 
buffer and drive it to the video interface. It also generates the required timing and control 
signals (horizontal sync, vertical sync, field, and blanking). A typical MPC823 video system 
is illustrated in Figure 19-1. 


FRAME 
BUFFER 


MPC823 | 
Py ead fae ee ee ea et e SYSTEM RAM 










SYSTEM i SYSTEM BUS 


_( ep TFT 
PANEL 
DIGITAL - 
Ste PANEL 
ENCODER 


Figure 19-1. Typical MPC823 Video System 





INTERNAL BUS 
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19.1 FEATURES 


The following list summarizes the features of the video controller: 


@ | 


e Supports Digital TFT LCD Panels and Analog NTSC/PAL Displays 
e Sequential RGB, 4:4:4, and 4:2:2 YC,C, (CCIR 601) Digital Component Video Formats 
e CCIR-656 Compatible 8-Bit Interface Port 
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Programmable Control for Horizontal Sync, Vertical Sync, Field, Blanking, Polarity, and 
Timing Generation with Half-Clock Resolution 


Supports Interlace/Noninterlace Scanning Methods 





Programmable Display Active Area 


Programmable Background Color for Inactive Areas 

¢ Smooth Switching Between Two Picture Formats 

e Supports Hardware Pan/Scroll Options in a Zoomed Buffer 
Glueless Interface to Most Digital Video Encoders 


e Burst Read DMA Cycles Are Used for Maximum Bus Performance 
¢ End-of-Frame and Bus Exception Interrupt Generation 


19.2 OPERATION 


The video controller consists of a register set, DMA controller with FIFOs, and a video 
control RAM array, as shown in Figure 19-2. The video controller RAM array provides the 
proper sequencing and control signal generation needed to synchronize the datastream 
through the FIFOs. The video controller, a standalone module, is programmed using a set 
of configuration registers. Once the registers have been configured and the video controller 
is enabled, the DMA controller initiates burst read cycles to display memory. 
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Figure 19-2. Video Controller Block Diagram 


19.2.1 The Video Controller Clock 


The video controller master clock source can either be the LCDCLK, which is generated by 
the system interface unit, or the external video clock signal (CLK). Refer to 

Section 5.2.1 System Clock and Reset Control Register and Section 5.3.4.4 The LCD 
Clocks for more information. LCDCLK is derived from the SPLL. If the external video clock 
is enabled by setting the CSRC bit in the VCCR, you must provide an external video clock 
(CLK) at the port D input. 


Note: If an external video clock (CLK) is used, then the ratio between that external 
clock and GCLK1 must not be greater than 1.25:1. For example, if your system 
clock is 50MHz, then the CLK input cannot exceed 62.5MHz. 
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Figure 19-3. Output Timing Example 


19.2.2 FIFO and DMA Control 


The video controller FIFO consists of 24 32-bit entries. The DMA control block handles all 
data transfers to the FIFOs and keeps them filled. At the appropriate time, each FIFO is filled 
by the DMA control block in 16-byte transfers. The frame buffer address must be 16-byte 
aligned. When the video controller is enabled, video data transfers to the panel start after 
five DMA burst accesses have filled the FIFOs. See Section 16.5.1 SDMA Bus Arbitration 
and Transfers for the proper arbitration configuration between the video controller DMA 
and SDMA. The FIFO has two sets of control registers (0 and 1) associated with the video 
RAM arrays (RAM_0O or RAM_1 appropriately). If there are problems with the screen 
blanking when your caches are on, set the SDCR to 0x40. 


The DMA control supports both interlace and noninterlace euiesane scanning schemes. 
In interlace mode, the DMA fetches the video components of odd lines from display frame 
buffer A followed by the even lines from display frame buffer B. In noninterlace mode, the 
lines are fetched sequentially from buffer A. No matter which mode you use, the video 
components of a line must be stored in an integer number of bursts. 


If the FIFO underruns during a frame, the video controller forces background video on the 
screen until synchronization between the FIFO and video control RAM array is regained. 
Synchronization means the FIFO and the video control RAM array are ready to display a 
frame from its beginning. At that point, the video controller starts reprocessing the frame at 
the beginning of the video control RAM array. 


19.2.3 Image Sizes 


The video controller can be used to display an image that is smaller than the size of the 
display. The area that is used to display the image is defined as the “active display area” and 
its video components are taken from the frame buffer. The inactive area is driven with a 
single user-programmable default background color. The video controller changes smoothly 
between two image sizes without disturbing the video timings. A display format is defined by 
the pattern in the RAM array (set RAM_0O or RAM_1) and the appropriate FIFO control 
register set (set_O or set_1). The active RAM set contains the pattern associated with the 
currently displayed image and the other RAM set contains the pattern associated with the 
second image. 
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After you program the inactive RAM set and corresponding FIFO control register set, change 
the ASEL bit in the VCCR to the value of the inactive set. The video controller will switch 
between the currently active set and the inactive set at the boundary of the frame. The CAS 
bit in the VSR reflects the currently active set. 


You can also force background video frames without disturbing the video timings by setting 
the BD bit in the VCCR. During this time, the FIFO is flushed and allows you to reprogram 
the current FIFO buffer address pointer registers. You can also switch between the currently 
active and inactive sets during this period. After clearing the BD bit, the video controller will 
continue operating according to the current RAM set and FIFO control register set. 
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oy A Note: Ifthe images contain less than 24 words of data, the video controller will not have 
| time to change images smoothly. You should use the force background video 
method described above to ensure correct operation. 


19.3 REGISTER MODEL 


19.3.1 Video Controller Configuration Register 


The 16-bit, memory-mapped, read/write video controller configuration register (VCCR) 
contains the mode and configuration bits for the video controller. 
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IMMR & OxFFFFO000) + 0x800 


DDT—Data Drive Timing 
This bit determines when the data changes. 


O= The video controller drives new data on the rising edge of the video clock. 
1 = The video controller drives new data on the falling edge of the video clock. 


DP—Data Polarity 


O= The data polarity is active high. 
1 = The data polarity is active low. 


MOTOROLA MPC823 USER’S MANUAL 19-5 


@ 


= 
=] 
m 
.e) 
‘?) 
oO 
_ = 
+ 
= 
_?) 
~ 
fa 
m 
= 





Video Controller 


DPF—Default Pixels Format 
This bit defines the format of the background video components. 


0 = BGND1, BGND2, BGND3 values will be used for the inactive area (BGND1, 
BGND2, BGND3, BGND1, BGND2, BGNDS.....). This setting is used for RGB 
encoding. : 

1= BGND1, BGND2, BGND3, BGND4 values will be used for the inactive area 
(BGND1, BGND2, BGND3, BGND4, BGND1, BGND2, BGND3, BGND4....). This 

-_ setting is used for YC,C, format encoding (Y;C,Y2C,). 


Bits 3 and 13—Reserved 
These bits are reserved and must be set to 0. 


lEN—Interrupt Enable 


O= The end-of-frame (EOF) interrupt is disabled. 
1 = The end-of-frame (EOF) interrupt is enabled. 


EIEN—Exception Interrupt Enable 


O= The underrun/bus error interrupt is disabled. 
1 = The underrun/bus error interrupt is enabled. 


IRQL—Interrupt Request Level . 


This field contains the priority request level of the video controller’s interrupt that is sent to 
the system interface unit. Refer to Section 12.3.3 Programming the Interrupt Controller 
for more information. This will generate an interrupt request level with a vector in the SIVEC 
register if enabled with the SIMASK register. Both EOF and the exception interrupts use the 
same request level. 000 is the highest priority level and 111 is the lowest. 


BO—Byte Order 


O= PowerPC little-endian byte order. 
1 = Big- or little-endian byte order. 


ATl—Address Type 


This field contains the value that you want to appear on the AT pins when the associated 
SDMA channel accesses memory. ATO will always be driven to 1. Refer to 
Section 13.4.7.3.4 Address Space Attributes for address type descriptions. 


CSRC—Clock Source 
This bit controls the clock source to the video controller. 


0 = The video controller source is LCDCLK. 
1 = The video controller source is the SHIFT/CLK/CLK pin (PD93). 


VON—Video Controller On 


0 = Video controller operation is disabled. 
1 = Video controller operation is enabled. 
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19.3.2 Video Status Register 


The 8-bit memory-mapped video status register (VSR) is used to report certain events to the 
core. When an event is recognized, the video controller sets its corresponding bit in the 
video status register, regardless of the corresponding mask bit. The video status register 
can be read at any time. A bit is cleared by writing a one (writing a zero has no effect). More 
than one bit may be cleared at a time. 
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Bits O and 2—4—Reserved 
These bits are reserved and should be set to 0. 


CAS—Current Active Set 
This read-only bit indicates the currently active RAM array and FIFO control register set. 


O= RAM_O and FIFO register set_O are currently active. 
1 = RAM_1 and FIFO register set_1 are currently active. 


BERR—Bus Error 


This status bit is set if a read cycle associated with the video controller was terminated by 
the assertion of a TEA signal. A maskable interrupt is generated to the core for as long as 
this bit is set. 


UN—Underrun 


This bit indicates that a FIFO underrun condition has been detected. An underrun condition 
occurs when the video controller FIFO is empty before a frame is completed. If the EIEN bit 
is set in the VCCR, then an interrupt is generated to the system interface unit at the level 
specified in the IRQL field of VCCR. 


EOF—End Of Frame 

This status bit is set when a RAM line, with the INT bit set, is executed. If the RAM line is 
repeated for more than one clock cycle, EOF will only be set at the last cycle of execution. 
This bit is typically used to mark the completion of a frame. If the IEN bit in the VCCR is 
enabled, an interrupt is generated to the system interface unit at the level specified in the 
IRQL field of VCCR. 
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19.3.3 Video Command Register 
The 8-bit video command register (VCMR) is used to control the display format. 


@ 


VCMR 
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(IMMR & OxFFFFO000) + 0x806 


Bits 0O-5—Reserved 
These bits are reserved and should be set to 0. 


ASEL—Active Set Select 


This bit selects one RAM array and FIFO control register set to be active for the next frame. 
The current set selection is reflected in the CAS bit of the VSR. 


0 = Selects RAM_O and FIFO register set_0 as the active set. 
= Selects RAM_1 and FIFO register set_1 as the active set. 


Note: Once the ASEL bit is changed, you cannot access video RAM until the CAS bit 
in the VSR reflects the change. 





BD—Blank Display 
When set, this bit forces the background video to be displayed and flushes the current FIFO. 


Q= Display the image from the frame buffer. 
1 = Force background video and flush FIFO. 
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19.3.4 Video Background Color Buffer Register 


The 32-bit, read/write video background color buffer (VBCB) register holds components for 
the background video. It is used as the source of video data for the inactive area of the 
display, according to the DPF bit in the VCCR. When you are using the ADV7176, this 
register should be programmed as C,YC,Y. 


cc 
Lu 
= 
| 
2) 
oc 
a 
= 
o) 
1.) 
Oo 
uu 
Q 
> 


VBCB 





(IMMR & OxFFFFO000) + 0x80A 





BGNDx—Background Color Component 1—4 
This field represents the color component based on the RGB or YC,C, format. 
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19.3.5 Video Frame Configuration Register (Set 0) 


The 32-bit, memory mapped, read/write video frame configuration register set 0 (VFCRO 
holds the display horizontal and vertical size, as well as the gap between two sequential 
lines. 


(IMMR & OxFFFFO000) + 0x812 





SFBO—Single Frame Buffer 0 


This bit controls whether the video controller displays an image from a single frame buffer 
A) or from both frame buffers (A and B). 


O= Frame B is valid. 
1 = Frame B Is not valid. 


Bits 1-2—Reserved 
These bits are reserved and should be set to 0. 


VPC0O—Vertical Pixel Count 0 
This field defines the number of lines for a field. 


Note: The value of the VPCO field should be non-zero or an error will occur. 





GAP0—Gap 0 


This field defines the gap in memory between the end of a line and the beginning of the next 
line in full burst units. For regular noninterlace mode, this field is set to 0. For regular 
interlace mode, it is set to the value in the NBPLO field. For example, hardware pan/scroll 
options in a zoomed buffer can be implemented by using the GAPO field with an appropriate 
field buffer start address. For example, with 720 pixels in YC,C, format, GAPO should be 
Ox5A. 
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NBPLO—Number of Bursts per Line 0 
This field defines the number of bursts per line. 


Note: The value of the NBPLO field should be non-zero or an error will occur. 
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19.3.6 Video Frame Buffer A Start Address Register (Set 0) 


Th 32-bit video frame buffer A start address register set 0 (VFAAO) holds the start address 
of the set_O odd field. Since all bursts must be 16-byte aligned, this register does not use 
the four least-significant bits of the address. 





(IMMR & OxEFFFO000) + 0x816 





NOTE: X = “Don’t Care” and — = Undefined. 


FAAOQ—Frame Buffer A Start Address for Set 0 
This field designates the start address of the frame buffer A set 0 in system memory. 
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19.3.7 Video Frame Buffer B Start Address Register (Set0O) 


The 32-bit video frame buffer B start address register set 0 (VFBAO) holds the start address 
of the set_O even field. Since all bursts must be 16-byte aligned, this register does not use 
the four least-significant bits of the address. 





NOTE: X = “Don’t Care” and — = Undefined. 


FBAO—Frame Buffer B Start Address for Set 0 


his field designates the start address of the frame buffer B set 0 in system memory. 
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19.3.8 Video Frame Configuration Register (Set 1) 


The video frame configuration register set 1 (VFCR1) has the same structure as VFCRO, 
except it belongs to set 1 and VFCRO belongs to set 0. The value of the VPC1 and NBPL1 
fields should be non-zero or an error will occur. 


VFCR1 


SFB1 | RESERVED VPC1 GAP1 


(IMMR & OxFFFF0000) + 0x81E 


SFB1—Single Frame Buffer 1 


This bit controls whether the video controller cpr an image from a single frame buffer 
(A) or from both frame buffers (A and B). 


O= Frame B is valid. 
1 = Frame B is not valid. 


Bits 1-2—Reserved 
These bits are reserved and should be set to 0. 


VPC1—Vertical Pixel Count 1 
This field defines the number of lines for a field. 


GAP1—Gap 1 


This field defines the gap in the memory between the end of a line and the beginning of the 
next line in full burst units. For regular noninterlace mode, this field is set to 0. For regular 
interlace mode, it is set to the value in the NBPL1 field. For example, hardware pan/scroll 
options in a zoomed buffer can be implemented by using the GAP1 field with an appropriate 
field buffer start address. 


NBPL1i—Number of Bursts per Line 1 
This field defines the number of bursts per line. 
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19.3.9 Video Frame Buffer A Start Address Register (Set 1) 


The 32-bit video frame buffer A start address register set 1 (VFAA1) holds the start address 
of the set_1 odd field. Since all bursts are required to be 16- -byte mote this register does 
not use the four least-significant bits of the address. 
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VFAA1 
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(IMMR & OxFFFFO000) + 0x822 


NOTE: X = - “Don’t Care” and — = Undefined. 


-FAA1—Frame Buffer A Start Address for Set 1 
This field designates the start address of the frame buffer A set 0 in system memory. 
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19.3.10 Video Frame Buffer B Start Address Register (Set 1) 


The 32-bit video frame buffer B start address register set 1 (VFBA1) holds the start address 
of the set_1 even field. Since all bursts are required to be 16-byte aligned, this register does 
not use the four least-significant bits of the address. 


VFBA1 
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NOTE: X = “Don’t Care” and — = Undefined. 





FBA1—Frame Buffer B Start Address for Set 1 
This field designates the start address of the frame buffer B set 0 in system memory. 
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19.4 VIDEO CONTROLLER RAM ARRAY 


The video controller state machine controls data that is shifted out to the video port as well 
as the timing patterns of the HSYNC, VSYNC, FIELD, and BLANK signals. The video RAM 
consist of two RAM arrays—RAM_0O and RAM_1—that contain 64 32-bit entries. At any 
given time, one RAM array actively drives the panel and controls video controller operation, 
while the other is inactive but modifiable. You can switch between the two RAMs at any time, 
but your change will not take effect until the end of the frame. The CAS bit in the VSR reflects 
the RAM that is active. An entry in the active RAM is read each video clock and specifies 
the state of the video port signals for the next CNT video clocks. CNT is specified by a 
special field within the entry. The next entry is read and used after the CNT clock periods of 
the previous entry. A few entries can be repeated in a loop to generate a repetitive pattern. 
Read/write operations are always directed to the inactive RAM array and can be performed 
anytime the active RAM controls the video controller and display operation. Since you can 
only access one RAM array (the inactive one) at a time, both RAMs are mapped to the same 
address space. The RAM arrays are not initialized after power-on and any access to the 
RAM array is discouraged while the video controller clock inputs are not operating. The 
video RAM array block diagram is illustrated in Figure 19-4. 











32 BITS WIDE 


ADDRESS GENERATOR 


CURRENT ENTRY POINTER 
ENTRY DURATION COUNTER 


RAM ARRAY 0 


64 
B ENTRIES 
= DEEP 
LOOP COUNTER 
LOOP START POINTER 


VIDEO 
CLOCK TIMING GENERATOR 


VSYNC SYNC FIELD BLANK 
Figure 19-4. Video RAM Array Block Diagram 
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19.4.1 Video RAM Word Format 


The video RAM word specifies the timing of all external signals controlled by the video 
controller. 


VIDEO RAM WORD 





ee & OxFFFFO000) + 0xBO0-OxBFE 






2 eS 
[aw [WS 


(IMMR & OxFFFF0000) + 0xB00-0xBFF 


NOTE: — = Undefined. 






HR—Horizontal Sync on Rising Edge of the Clock 


O= The value of the HSYNC signal will be 0 after the rising edge of the clock. 
1 = The value of the HSYNC signal will be 1 after the rising edge of the clock. 


HF—Horizontal Sync on Falling Edge of the Clock 


O= The value of the HSYNC signal will be O after the falling edge of the clock. 
1 = The value of the HSYNC signal will be 1 after the falling edge of the clock. 


VR—Vertical Sync on Rising Edge of the Clock 


O= The value of the VSYNC signal will be O after the rising edge of the clock. 
1 = The value of the VSYNC signal will be 1 after the rising edge of the clock. 


VF—Vertical Sync on Falling Edge of the Clock 


O= The value of the VSYNC signal will be O after the falling edge of the clock. 
1 = The value of the VSYNC signal will be 1 after the falling edge of the clock. 


FR—Field on Rising Edge of the Clock 


0 = The value of the FIELD signal will be O after the rising edge of the clock. 
1 = The value of the FIELD signal will be 1 after the rising edge of the clock. 


FF—Field on Falling Edge of the Clock 


O= The value of the FIELD signal will be 0 after the falling edge of the clock. 
1 = The value of the FIELD signal will be 1 after the falling edge of the clock. 
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BR—Blanking on Rising Edge of the Clock 


O= The value of the BLANK signal will be O after the rising edge of the clock. 
1 = The value of the BLANK signal will be 1 after the rising edge of the clock. 


@ 





BF—Blanking on Falling Edge of the Clock 


O= The value of the BLANK signal will be O after the falling edge of the clock. 
1 = The value of the BLANK signal will be 1 after the falling edge of the clock. 





= 
=) 
m 
oO 
?) 
eo) 
= 
— 
3] 
2) 
| 
aes 
iu 
wv 





| “oO Note: All pins are general-purpose and can be programmed according to your 
requirements. The signal pin value only changes at the first cycle in which the 
line is valid. If a line is valid for more than one clock (CNT > 1), the signal holds 
its last assigned value. 


Bits 8-13 and 17-18—Reserved 
These bits are reserved and should be set to 0. 


VDS—Video Data Select 


This field selects the source of the video data or holds the last value of the data for the next 
CNT cycle. 


00 = Select active video from display frame buffer (FIFO output). 

01 = Select inactive (background) video from the background color buffer. 
10 = Hold last value of data. 

11 = Reserved. 


INT—Interrupt 


0 = Do not generate a interrupt to the core. 
1 = Generate a maskable interrupt (end of frame) after this entry completes and before 
the next one begins. 
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LCYC/CNT—Loop Cycles/Clock Count 


This field is a special field that is used for two purposes. It is used as the LCYC field if the 
LP bit is set to mark the beginning of a loop and it is used as a CNT field to count the number 
of clocks to hold a line. CNT is assumed as 1 if the LCYC field is valid (LP = 1 and at 
beginning of loop). 


If LP = 0, then 
CNT = the number of video clocks for this entry. 


lf LP = 1 and this is the beginning of the loop, then 
LCYC = the number of loop cycles and CNT is already defined equal to 1. 


lf LP = 1 and this is the end of the loop, then 
CNT = the number of video clocks for this entry. 


“Oo Note: The value of the LCYC/CNT field should be >1 or erroneous operation will occur. 


LP—Loop 

This bit marks the beginning and end of a loop. The entry that marks the start of a loop 
should have the LP bit and the LCYC field set to the number of desired iterations. The entry 
that marks the end of a loop should have the LP bit set as well. Since only one bit marks the 
beginning and end of a loop, nested loops are not possible. 


LST—LAST 


O= This is not the last valid entry. 
1 = This is the last valid entry. 


19.5 PROGRAMMING EXAMPLES 


The following examples demonstrate how to program the video controller to support an 
NTSC or PAL interlaced display using Analog Devices ADV7176 video encoder with a few 
assumptions. 

e The CCIR 601 4:2:2 video data format is used. 


e The ADV7176 is controlled by the HSYNC, BLANK, and FIELD signals (MODE1:slave 
option) and has already been configured using I7C. 


e The image data resides in consecutive addresses of the memory. 
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19.5.1 NTSC Example 


The NTSC (National Television Standards Committee) broadcast method defines a virtual 
screen of 525 lines where each line is 858 pixels long, but you can only see 485 of them. 
Each horizontal line contains 720 pixels during the active line period and the rest of the line’s 
pixels are presented during the digital blanking. Figure 19-5 illustrates how the frame is 
divided into the following seven sections that correlate with the behavior of the FIELD and 
BLANK signals: 


e Lines 1-3: frame 1 retrace blanking 

e Lines 4-21: frame 0 blanking 

e Lines 22-261: frame 0 active video for odd lines 

e Lines 262-265: frame 0 retrace blanking 

e Lines 266-284: frame 1 blanking 

e Lines 285-524: frame 1 active video for even lines 
e Line 525: frame 1 retrace blanking 


ob FIELD 1 
BLANKING 
ODD FIELD Maia 
ACTIVE VIDEO 
FRAM BUFFER A 
BLANKING 
— FIELD 1 


EVEN FIELD 
ACTIVE VIDEO 
FRAME BUFFER B 


lee eee 


|[-_["__RETRACE BLANKING |__| 
Figure 19-5. Interlaced NTSC Format 
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Figure 19-6 illustrates the horizontal timing of a single horizontal line, which is represented 
by five RAM entries: 


e A—The section of the line where both blanking and HSYNC are asserted. 
e B—The section of the line where HSYNC is negated and blanking is asserted. 


¢ C—tThe section of the line where both signals are negated while the driven data is 
background 


cc 
Lu 
—! 
—_ 
eo) 
cc 
= 
2) 
oO 
O 
Lu 
=) 
> 


e D—tThe section of the line where both signals are negated while the driven data is the 
image data. 


e E—The section of the line where blanking is asserted and HSYNC is negated. 





LINE 3 


FIELD 





16 PIXELS 
(32 CLOCKS) 
118 PIXELS 720 PIXELS 
(236 CLOCKS) (1440 CLOCKS) 
858 PIXELS 
(1716 CLOCKS) 
4 PIXELS 
(8 CLOCKS) 


Figure 19-6. NTSC Horizontal Timing 


MOTOROLA -MPC823 USER’S MANUAL 19-21 


Video Controller 


19.5.1.1 NTSC PROGRAMMING PROCEDURE EXAMPLE. Use the following procedure 
to program your video controller using an ADV7176 video encoder in slave mode with video 
data in CCIR 4:2:2 format. A clock crystal provides 27MHz to CLK. Our website has a 
comprehensive example that includes using I2C to program the ADV7176. 


@ 


e Program the VBCB register with the components of the background video. For a black 
background, write 0x80108010 to the VBCB register. 


¢ Program 0x07805ASA to the VFCR1. It defines a field of 240 lines and each line 
consists of 90 bursts of data. There is a GAP1 of one line (90 bursts) long between two 
consecutive lines due to interlace mode. 


e Program the start address of the odd field to VFAA1 register. 


e Program the start address of the even field to VFBA1 register. This address should be 
equal to VFAA1 address+0x5A0. 


e Use Table 19-1 to configure the video controller RAM array. 
e Write 0x02 to the VCMR to select RAM_1 and FIFO register set 1 as the active set. 


e Reset the ADV7176 and program the default NTSC settings, except for mode register 
1 (0x02), timing register O (0x02), and mode register 2 (0x08). 


e Convert your data to CbYCrY format for the ADV7176. Assuming each color ranges 
between 0 and 100, use the following equations to convert from RGB to YC,C, for the 
ADV7176: , 
void SetPixelRGB (int col, int row, PALLETE color) 


{ 
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int location; 
VYUY *address; 


location = screen.burstlength * (row+25) + ((col+55) / 2*4); 
address = (VYUY *) (location + (int) screen.base) ; 


if (col % 2) 


{ 
address -> Yl = 209 * (color.red + color.green + color.blue) / 300 +16 
address -> V = color.blue - color.red/4 - color.green*3/4 = 128; 


} 


else 


{ 


address -> Y2 = 209 * (color.red + color.green + color.blue) / 300 + 16 
address -> U = color.red - color.green*3/4 - color.blue/4 + 128; 


} 
e Program 0x2043 to the VCCR to operate the video controller. 
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Table 19-1. Video RAM Array Loaded with NTSC Example 


RAM RAM WORD FIELD 


ENTRY LINE DESCRIPTION 
feo [os [os Pree Pe ie 
01 Entry 0:LP=1—Beginning of loop. 
LCYC=3— at entries 0-3 three times. 
CNT=1—Hold this entry for one video clock. 
6 Ga a Md a cdc 


beketelctodditetoke Entry 2: CNT=1440—Hold this entry for 1440 video 
11 11 01 32 Entry 3:LP=1—End of loop. 
CNT=32—Hold this entry for 32 video clocks. 


ruere ta Lines 4-21, FIELD = 0, BLANK is asserted 
ee 4440 Ree (vertical blanking) 
ps2 {1 | 


240 









N 
(e) 
oO 


—_ —_ —_ —_ — 


Lines 22-261. ODD field active area, the horizontal 
line is repeated 240 times 


ine) NO —_ —_ —_ _ 


NO 

i) 
a fof ao a f if «aj o ee) es ee eS = J) ai] 
a fof] =a f/,/—o.;], =] — =a | 1] ou kf ek | ek 


hh, 
_, 
p 
iN 
(eo) 


ine) 
oe) 
i,t 


—_ 


po Lines 262-265, FIELD = 0, BLANK asserted 
(vertical; blanking) 


oh. 


— 
E 
Ey 
— 
mk 
i 
& 
© 


ah, 


NO _—h (de) 
ft 


Lines 266-284, FIELD = 1, BLANK asserted 


4440 geo. (vertical; blanking) 


mM ,_M] 
co 


93 base | ou Lines 285-524. EVEN Field active area 


i) 
aS 


2 


“J 


(vertical blanking) 


N 7] MO 
oO} © 


EES 
2s [o[e |, ot 
Line 525, FIELD = 1, BLANK is asserted 


NOTE: HX = HR:HF and VX = VR:VF. 
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19.5.2 PAL Example | 


_ The PAL (Phase Alternation Line) broadcast method defines a virtual screen of 625 lines, 
which are 864 pixels long. However, you can only see 576 of these lines. Each horizontal 
line contains 720 pixel during the active line period (which is visible to you) with the rest of 
the line’s pixels presented during digital blanking. Figure 19-7 illustrates how the frame is 
divided into six sections that correlate with the behavior of the FIELD and BLANK signals: 


¢ Lines 1-22: Frame 0 blanking 

° Lines 23-310: Frame 0 active video for odd lines © | | 
e Lines 311-312: Frame 0 for retrace blanking 

e Lines 313-335: Frame 1 blanking 

e Lines 336-623: Frame 1 active video for even lines 
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e Lines 624-625: Frame 1 retrace blanking 


LINE |BLANK] FIELD 


S 


BLANKING 


FIELD 0 
ODD FIELD 
ACTIVE VIDEO 
FRAME BUFFERA | 
BLANKING 
EVEN FIELD ace 


ACTIVE VIDEO 
FRAME BUFFER B 


RETRACE BLANKING 





Figure 19-7. Interlaced PAL Format 
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Figure 19-8 illustrates the horizontal timing of a single horizontal line that is represented by 
five RAM entries: 


e A defines the section of the line where the both the BLANK and HSYNC signals are 
asserted. 


e B defines the section of the line where the HSYNC signal is negated and BLANK is 
asserted. 


¢ C defines the section of the line where the HSYN 
while the driven data is background. 


e D defines the section of the line where the HSYNC and BLANK signals are negated 
while the driven data is the image data. 


e E defines the section of the line where the BLANK signal is asserted and HSYNC is 














©) 
) 


nd BLANK signals are negated 





negated. 
AB C D E 
LINE 3 
HSYNC 
FIELD 
BLANK 





12 PIXELS 
(24 CLOCKS) 
128 PIXELS 720 PIXELS 
(256 CLOCKS) (1440 CLOCKS) 
864 PIXELS 
(1728 CLOCKS) 
4 PIXELS 
(8 CLOCKS) 


Figure 19-8. PAL Horizontal Timing 
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19.5.2.1 PAL PROGRAMMING PROCEDURE EXAMPLE. Use the following procedure to 
program your video controller using an ADV7176 video encoder in slave mode with video 
data | in CCIR 4:2:2 format. 


@ 


° ‘Prograin the VBCB register with the components of the packoreanas video. For a black 
_ background write 0x80108010 to the VBCB register. 


Program 0x09005A5A to the VFCR1. It defines a field of 288 lines, in which each line 
consists of 90 burst of data. There is a GAP1 of one line (90 bursts) long between two 
consecutive lines due to interlace mode. 


Program the start address of the odd field to VFAA1 register. 


Program the start address of the even field to the VFBA1 register. This address should 
be equal to the VFAA1 address+0x5SA0. 


Use Table 19-2 to configure the video controller RAM array. 
Write 0x02 to the VCMR to select RAM_1 and FIFO register set 1 as the active set. 
e Program 0x2041 to the VCCR to operate the video controller. 
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Table 19-2. Video RAM Word Loaded with PAL Example 


RAM RAM WORD FIELD 
ENTRY LINE DESCRIPTION 
Liv | vx | rx | ox | vos | wr [rove] up | usr 


00 | oo | ot | o | 22 | 4 | 0 | 
} 4 | 14 | 00 | 00 | 00 | ot | o | 263] 0 | poner FIELD = 0, BLANK is asserted (vertical 
2 | 14 | 00 1440] 0 | 0 | 


a: 
TT 
aul 
mod 
rot 
oc 
= 
=z 
ro) 
©. 
ro) 
mot) 
Q 
=> 


© wm 


Entry 4: Be Inning of loo Yoop entries 4-8 288 
times). Assort HSYNC and LANK for 1 video clock. 
Entry 5: Assert BLANK and negate HSYNC for 255 
video clocks. 


Entry 6: Negate BLANK for 8 video clocks. Display 
video data from the VBCB. 





Entry 7: Display active video data from frame buffer 
for 1440 video clocks (720 pixels). 


ntry 8: Assert BLANK for 24 video clocks. 


ath, 

ho rs 
es iS 
oO 


Lines 311-312, FIELD = 0, BLANK asserted 
(vertical; blanking) 


a ee ee ee oe © 
Ne) Oo 
a © 
S13 
S16 


4 
oe) 

Mh | Rh 
Ba 


ines 313-335, FIELD = 1, BLANK asserted 
vertical; blanking) 


= joa J a 
COIN oy] on 
AA 
SS 


Lines 336-623. EVEN field active area 


Np fs 
oO} oO 


Lines 624-625, FIELD = 1, BLANK is asserted 
(vertical blanking) 
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NOTE: HX = HR:HF and VX = VR:VF. 


MOTOROLA MPC823 USER’S MANUAL 19-27 


Video Controller 


@ 


= 
=) 
m 
O 
QD. 
O 
si 
on 
eo) 
| eae 
mm. 
a] 





19-28 _ MPC823 USER’S MANUAL MOTOROLA 


SECTION 20 | 
DEVELOPMENT CAPABILITIES AND INTERFACE 


This section discusses the on-chip features that are used during the development phase. 
Background debug monitors and emulators are used to interface with this MPC823 
capability. Emulators require a level of control and observation that are in sharp contrast to 
the trend of modern microcomputers and microprocessors in which many bus cycles are 
directed to internal resources and are not externally visible. The same is true for bus 
analyzers. To enhance support for development tools, some of the development support 
functions are implemented in the silicon. Program flow tracking, watchpoint and breakpoint 
generation, and emulation systems that control core activity are just some of the features 
that allow you to efficiently debug systems based on the MPC823. 


20.1 FEATURES 


The following list summarizes the development features of the MPC823: 


© Program Flow Tracking 


L) Instruction show cycles 
[1 Data show cycles 

1) Branching 

(1 Exception trap 


e Watchpoint and Breakpoint Generation 


(i Four hardware breakpoints 
O Five watchpoint sources _ 


e Simple Hardware Interface 


L) High-speed data interface 
L} Internal status pins. 
[J] Freeze indication 


e Rich Control Register Set 
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Development Capabilities and Interface 


20.2 PROGRAM FLOW TRACKING 


The MPC823 provides many options for tracking program flows that impact performance in 
varying degrees. The information provided while tracking code flow can be compressed and 
captured externally and then parsed by a post-processing program using the 
microarchitecture defined here. The program instruction flow is visible on the external bus 
when the MPC823 is programmed to operate in serialized mode and show all fetch cycles 
on the external bus. When working in this mode, although tracking of the program instruction 
flow is simpler, the performance of the MPC823 is much lower than when working in regular 
mode. See Section 20.6.2.5 Instruction Support Control Register for more details about 
programming the core to operate in this mode. 


The MPC823 implements a prefetch queue combined with parallel, out-of- en and 
pipelined execution. These features, plus the fact that most fetch cycles are performed 
internally from the instruction cache, increases the performance but makes it very difficult to 
provide you with the real program trace. Instructions progress inside the core from fetch to 
retirement. An instruction retires from the machine only after it and all preceding instructions 
finish execution with no exception. Therefore, only retired instructions ¢ can be considered 
architecturally executed. 


Reporting program trace during retirement significantly complicates visibility and increases 
the die size for the two reasons—more than one instruction can retire in a clock cycle and it 
is harder to report on indirect branches during retirement. Because of this, program trace is 
reported during fetch and helps to reconstruct the instructions that actually retire after fetch 
canceled instructions are reported. Instructions are fetched sequentially until branches 
(direct or indirect), exceptions, or interrupts appear in the program flow or until a stall in 
execution forces the machine to avoid fetching the next address. These instructions can be 
architecturally executed or they can be canceled in any stage of the machine pipeline. 


To reconstruct a program trace, you need the program code in addition to the following 
MPC823 information: 


e A description of the last fetched instruction (stall, sequential, branch not taken, branch 
direct taken, branch indirect taken, interrupt/exception taken). 


e The addresses of all indirect flow changes targets. Indirect flow changes include all 
branches using the link and count registers as the target address, all interrupts/ 
exceptions, as well as rfi and mtmsr because it may cause a context switch. 


e The number of instructions canceled on each clock. 
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20.2.1 Basic Operation 


20.2.1.1 THE INTERNAL HARDWARE. To make the events that occur in the machine 
visible, a few dedicated pins are used. Also, a special bus cycle attribute called program 
trace cycle is defined. The program trace cycle attribute is attached to all fetch cycles that 
result from indirect flow changes. When program trace recording is required, you must 
program the appropriate registers to ensure that these cycles are visible on the external bus. 


The internal visible sync (VSYNC) signal, when asserted, forces all fetch cycles marked with 
the program trace cycle attribute to be visible on the external bus, even if their data is found 
in one of the internal devices. To enable the external hardware to properly synchronize with 
the internal activity of the core, VSYNC assertion and negation forces the machine to 
synchronize and marks the first fetch after the synchronization as a program trace cycle that 
be seen on the external bus. For more information about the activity of the external hardware 
during program trace, refer to Section 20.2.1.2 The External Hardware 


Note: To keep the pin count of the chip as low as possible, the VSYNC signal is not 
implemented as one of the chip’s external pins. Instead, it is asserted and 
negatedT using the serial interface implemented in the development port. For 
more information on this interface, refer to Section 20.4.3 The 
Development Interface Port. Forcing the core to show all fetch cycles 
marked with the program trace cycle attribute can be accomplished by either 
asserting the VSYNC signal or by programming the ISCT_SER fieldin the 
instruction support control (ICTRL) register. For more information, see — 
Section 20.2.2 Controlling Instruction Fetch Show Cycles. 


When the VSYNC signal is asserted, all fetch cycles marked with the program trace cycle 
attribute become visible on the external bus. These cycles generate regular bus cycles when 
the instructions reside in one of the external devices or generate address-only cycles when 
the instructions are in one of the internal devices. When the VSYNC signal is asserted, some 
performance degradation occurs because of the additional external bus cycles. Since this 
performance degradation is expected to be very small, you can program the machine to 
show all indirect flow changes, perform these additional external bus cycles, and maintain 
the same behavior when the VSYNC signal is asserted and negated. For more information, 
see Section 20.6.2.5 Instruction Support Control Register. 
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Development Capabilities and Interface 


The status pins are divided into two groups—the instruction queue status and the history 
buffer flush status. 


° » VFO: o1Visible | Instruction Queue Flushes Status 


Instruction queue status denotes the type of the last fetched instruction or how many 
instructions were flushed from the instruction queue. These status pins are used for 

both functions because queue flushes only happen in clocks where there is no fetch 

type information to be reported, as shown in Table 20-1. 


000-= None. 

001 = 1 instruction was flushed from the instruction queue. 

010 = 2 instructions were flushed from the instruction queue. 

011 = 3 instructions were flushed from the instruction queue. 

100 = 4 instructions were flushed from the instruction queue. 

101 = 5 instructions were flushed from the instruction queue. 

110 = Reserved. 

111 = Special case. See Section 20.2.1.1 The Internal Hardware. 


® 


Table 20-1. VF Instruction Type Encoding 


| ve | . . | INSTRUCTION TYPE VF NEXT CLOCK WILL HOLD 
}000 [Nome None Mor instruction type information 
ch 


Branch (direct or indirect) not taken 


LNAINdOTSA3G 
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VSYNC was asserted/negated and therefore the next 
aici will be marked with the program trace cycle 
attribute 


Interrupt/exception taken, the target will be marked with 
the program trace cycle attribute 


Branch indirect taken, rfi, mtmsr, isync and in some 
| cases mtspr, the target will be marked with the program 


| trace cycle attribute’ 


|Branch direct taken | 
Branch (direct or indirect) not taken | , 


~ NOTES: Unless the next clock VF = 111, refer to Section 20.2.1.1 The Internal Hardware. 







Queue flush information 


e VFLS[0:1]—Visible History Buffer Flushes Status 


History buffer flushes status indicates the number of instructions that are flushed from 
the history buffer on this clock. 


00 = None. 

01 = One instruction was flushed from the history buffer. 

10 = Two instructions were flushed from the history buffer. 

11 = Used for debug mode indication and should be ignored by the program trace 
external hardware. For details, refer to Section 20.4.2 Debug Mode. 
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20.2.1.1.1 Special Case Queue Flush Information. There is one special case where the 
queue flush information is expected on the VF pins. This is easily monitored since the only 
case where this can happen is when VF =111 and the maximum number of possible queue 
flushes is five. 


20.2.1.1.2 Program Trace In Debug Mode. When entering debug mode an 
interrupt/exception is reported on the VF pins (VF=100) and a cycle marked with the 
program trace cycle is externally visible. When the CPU is in debug mode, the VF pins equal 
000 and the VFLS pins equal 11. For more information on the MPC823 debug mode, refer 
to Section 20.4 Hardware Development System Interface. 


If the VSYNC signal is asserted/negated while the core is in debug mode, this information 
is announced when the first VF pins report as the core returns to regular mode. If VSYNC 
was not changed while in debug mode, the first VF pins report will be encoded as VF=101 
(indirect branch) due to the rfi instruction being issued. In both cases, the first instruction 
fetch after debug mode is marked with the program trace cycle attribute and is externally 
visible. When the MPC823 external bus is configures to operate at half the speed of the 
internal system (EBDF=1), the VF and VEFLS pins will not report fetch and flush information 
for the program trace capability. However, the internal freeze state of the processor will be 
reported on the VFLS pins. 


20.2.1.1.3 Sequential Instructions Marked As Indirect Branch. There are instances | 
where nonbranch or sequential instructions affect the machine similar to the way that _ 
indirect branch instructions affect it. These sequential instructions include rfi, mtmsr, isync, 
and mtspr to the BAR, CMPA-CMPH, COUNTA, COUNTB, ICTRL, ICR, LCTRL1, LCTRL2, 
and DER registers. 


The core marks these instructions as indirect branch instructions (VF = 101) and the 
following instruction address is marked with the program trace cycle attribute, as if it was an 
indirect branch target. Therefore, when one of these special instructions is detected in the 
core, the address of the following instruction is externally visible. The reconstructing 
software is now able to correctly evaluate the effect of these instructions. 


20.2.1.2 THE EXTERNAL HARDWARE. When a program trace is needed, the external 
hardware must sample the status pins—VF and VFLS—of every clock and mark the address 
of all cycles with the program trace cycle attribute. Program trace is used in various ways, 
but back trace and window trace are the most common methods. 
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20.2.1.2.1 Back Trace. This is useful when a record of the program trace is needed before 
an event occurs, such as system failure. If back trace is needed, the external hardware 
should start sampling VF and VFLS pins and the addresses of all cycles marked with the 
program trace cycle attribute immediately after reset is negated. Since the instruction show 
cycles programming defaults to show all out of reset, all cycles marked with the program 
trace cycle attribute are visible on the external bus. VSYNC should be asserted sometime 
after reset and negated when the actual event occurs. If show all is not the preferred mode 
for the instruction show cycles before the event actually occurs, VSYNC must be asserted 
before exiting show all mode. If the timing of the event in question is unknown, it is possible 
to use cyclic buffers. After the VSYNC signal is negated, the trace buffer contains the 
program flow trace of the program executed before the event in question occurred. 


20.2.1.2.2 Window Trace. This is useful when a record of the program trace between two 
events is required. The VSYNC pin should be asserted between these two events. After 
VSYNC is negated, the trace buffer will contain information describing the program trace of 
the program executed between the two evenis. 


20.2.1.2.3 Synchronizing the Trace Window to the Internal Core Events. The 
VSYNC signal is asserted or negated using the serial interface implemented in the 
development port. To synchronize the assertion or negation to an internal core event, the 
internal breakpoint hardware should be used with debug mode. This method is available 
only when debug mode is enabled. For more information on debug mode, refer to 
Section 20.4 Hardware Development System Interface. 


To synchronize the trace window to the internal core events, follow these steps: 


1. Enter debug mode either straight from reset or when using a debug mode request. 


2. Program the hardware to break on the event that marks the start of the trace window 
| using the control registers defined in Section 20.3 Generating Watchpoints And 
Breakpoints. 


3. Enable debug mode entry for the sioaaninied breakpoint in the debug enable 
register. See Section 20.6.3.2 Debug Enable Register for details. 


4. Return to the regular code run. The hardware generates a breakpoint when the event 
in question is detected and the machine enters debug mode. 


5. Program the hardware to break on the event that marks the end of the trace window. 
6. Assert the VSYNC signal. 


7. Return to the regular code run. The first report on the VF pins is VSYNC, where 
VF = 011. The external hardware starts sampling the program trace information after 
the VF pins indicate VSYNC. The hardware generates a breakpoint when the event in 
question is detected and the machine enters debug mode. 


8. Negate the VSYNC signal. 


9. Return to the regular code run and issue an rfi instruction. The first encoding on the 
VF pins is VSYNC, where VF = 011. The external hardware stops sampling the 
program trace information after recognizing VSYNC on the VF pins. 
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20.2.1.2.4 Detecting the Trace Window Start Address. When using back trace, latching 
VF, VFLS, and the address of the cycles marked program trace cycle should all start 
immediately after reset is negated. The start address is the first address in the program trace 
cycle buffer. When using window trace, latching of VF, VFLS, and the address of the cycles 
marked as program trace cycle should all start immediately after the first VSYNC is 
recognized on the VF pins. The start address of the trace window should be calculated 
according to the first two VF pin reports. Assume VF1 and VF2 are the first two VF pin 
reports and T1 and T2 are the two addresses of the first two cycles marked with the program 
trace cycle attribute that were latched in the trace buffer. Use the following table to calculate 
the trace window start address. 


Table 20-2. Detecting the Trace Buffer Starting Point 


011 VSYNC is asserted and followed by a sequential 
VSYNC Sauer instruction. the start address is T1. 
011 110 T1-4+4 VSYNC is asserted and followed by a taken direct branch. 
VSYNC Branch Direct Taken Offset(T1 - 4) the start address is the target of the direct branch. 
VSYNC is asserted and followed by a taken indirect 
VSYNC Branch indirect Taken pene the start address is the target of the indirect 
ranch 


20.2.1.2.5 Detecting VSYNC Assertion/Negation. Because the VF pins are used to 
report both instruction type and queue flush information, the external hardware must take 
special care when trying to detect the assertion/negation of VSYNC. When VF = 011, itis a 
VSYNC assertion/negation report only if the prior value of VF was 000, 001, or 010. 







20.2.1.2.6 Detecting the Trace Window End Address. The information on the status 
pins that describes the last fetched instruction and last queue/history buffer flush changes 
every clock. Cycles marked as program trace cycle are generated on the external bus only 
when the system interface unit arbitrates over the external bus. Therefore, there is a delay 
between the report that a cycle marked as program trace cycle is performed and the actual 
time that this cycle can be detected on the external bus. 


When you negate VSYNC using the serial interface of the development port, the core delays 
reporting that VSYNC occurred on the VF pins until all addresses marked with the program 
trace cycle attribute are externally visible. Therefore, the external hardware should stop 
sampling VF, VFLS, and the address of the cycles marked as program trace cycle 
immediately after VF = VSYNC. The last two instructions reported on the VF pins are not 
always valid. Therefore, at the last stage of the reconstruction software, the last two 
instructions should be ignored. 
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20.2.1.3 COMPRESSION OF CANCELLED INSTRUCTIONS. To store all the information 
generated on the pins during program trace (5 bits per clock + 30 bits per show cycle), a 
large memory buffer is required. However, since this information includes events that were 
cancelled, compression is possible and can be very beneficial in this situation. External 
hardware can be added to eliminate all canceled instructions and reports only on taken or 
not taken branches, indirect flow change, and the number of sequential instructions after the 
last flow change. | | | | | 


20.2.2 Controlling Instruction Fetch Show Cycles 


Instruction fetch show cycles are controlled by the bits in the ICTRL register and the state 
of the VSYNC signal. The following table defines the level of fetch show cycles generated 
by the core. Table 20-3 shows the types of fetch show cycles determined by the ISCT_SER 
field. A cycle marked with the program trace cycle attribute is generated for any change in 
the state of VSYNC. 


Table 20-3. Fetch Show Cycle Types 





ISCT_SER INSTRUCTION 
FETCH SHOW CYCLE ~ 
CONTROL FIELD 






SHOW CYCLES 
GENERATED 






All Fetch Cycles 


X01 | All Change of, fsa (Direct and 
po TX Ne show Cycles Are Performed 


NOTE: Only cycles that access storage assert the TS signal. All cycles that involve “show 
cycles” are marked by asserting the STS signal. When you need to sample the 
_ show cycle address and attributes, the STS signal should be enabled by 
programming the DBGC field of the SIUMCR. See Section 12.12.1.1 SIU Module 
Configuration Register for details. | 







20.3 GENERATING WATCHPOINTS AND BREAKPOINTS 


When detected, watchpoints are reported to the external world on dedicated pins but do not 
change the timing and flow of the machine. When breakpoints are detected, they force the 
machine to branch to the appropriate exception handler. The core supports watchpoints that 
are generated inside the core as well as breakpoints that are generated inside and outside 
the core. {< 


In the core, as in other RISC processors, saving and restoring the machine state on the 
stack during exception handling is done in the software. When the software is in the middle 
of saving and restoring, the MSR, bit is cleared. Exceptions that occur are handled by the 
core when the MSR, bit is clear and they result in a nonrestartable machine state. For more 
information refer to Section 6.3.4.1 Restartability After An Interrupt. 
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In general, breakpoints are recognized in the core only when the MSR,, bit is set, which 
guarantees machine restartability after a breakpoint. In this working mode, breakpoints are 
masked. There are times when it is preferable to enable breakpoints even when the MSRa, 
bit is clear, even though there is a risk of causing a nonrestartable machine state. In 
programmable nonmasked mode, an external development system can choose to assert a 
nonmaskable external breakpoint. Watchpoints are not masked and are always reported on 
the external pins, regardless of the value of the MSRp, bit. The counters, although they are 
counting watchpoints, are part of the internal breakpoints logic and are not decremented 
when the core is in masked mode and the MSR, bit is clear. 


Internal watchpoints are generated when a user-programmable set of conditions are met. 
Internal breakpoints can be programmed to be generated either when one of the internal 
watchpoints is asserted or after an internal watchpoint is asserted for user-programmable 
times. Programming a certain internal watchpoint to generate an internal breakpoint can be 
done either in the software, by setting the corresponding software trap enable bit, or on-the- 
fly using the serial interface of the development port to set the corresponding trap enable bit. 


External breakpoints can be generated by any of the system peripherals, including those 
found on or outside the MPC823 or those found by an external development system. 
Peripherals on the external bus use the serial interface of the development port to assert an 
external breakpoint. 


20.3.1 Internal Watchpoints and Breakpoints 


Internal watchpoints and breakpoints are used in software debugging and the sources are 
illustrated in Figure 20-1. For the recoverable interrupt bit of the MSR, see Section 6 
The PowerPC Core. Watchpoints do not stop your code from executing, but they indicate 
when you have passed a certain testing point. Breakpoints are actually the points at which 
execution is stopped. For more information on external breakpoint support, refer to 
Section 20.4 Hardware Development System Interface. Internal breakpoint and 
watchpoint support is based on: 


e Eight comparators that compare information on instruction and load/store cycles 

¢ Two counters | 

e Two AND-OR logic structures 
The comparators perform a comparison on the instruction address (l-address), the load/ 
store address (L-address), and the load/store data (L-data). The comparators can detect the 
following conditions: 

e Equal to 

e¢ Not equal to 

e Greater than 

e Less than 


Greater-than-or-equal-to and less-than-or-equal-to are easily obtained from these four 
conditions. Refer to Section 20.3.1.5 Generating Compare Types for more information. 
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Development Capabilities and Interface 


Using the AND-OR logic structures “in range” and “out of range”, detections of address and 
data comparators are supported. Using the counters, you can program a breakpoint to be 
recognized after an event has been detected after a predefined number of times. 


DEVELOPMENT otetaccite Bade ote tas) 
SYSTEM OR ! CPMWCODE | x) BIT WISE AND 
EXTERNAL DEVELOPMENT $s: 
ACCESSIBLE 


PERIPHERALS 





! INTERNAL ! 
| | PERIPHERALS |! ) x) orwse = 


MASKABLE BREAKPOINT = . 
DEVELOPMENT EE BREAKPOINT 
PORT 
_ | DEVELOPMENT PORT TRAP ENABLE BITS | )) 
| a - BREAKPOINT 
SOFTWARE TRAP ENABLE BITS 7OGeU 
LOTRL2 NONMASKED CONTROL BIT 2 
MSR i ar 


INTERNAL 
WATCHPOINTS 
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Figure 20-1. Watchpoint and Breakpoint Support in the Core 


The L-data comparators operate on load or store fixed-point data. When operating on 
fixed-point data the L-data comparators perform a comparison on bytes, half-words, and 
words. They treat numbers as either signed or unsigned values. The comparators generate 
match events and then instruction match events enter the instruction AND-OR logic where 
the instruction watchpoints and breakpoint are generated. The asserted instruction 
watchpoints can generate the instruction breakpoint. Two different events can decrement 
one of the counters. When a counter on one of the instruction watchpoints expires, the 
instruction breakpoint is asserted. 
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The instruction watchpoints and load/store match events on the address/data comparators 
enter the load/store AND-OR logic where the load/store watchpoints and breakpoint are 
generated. When aserted, the load/store watchpoints can generate the load/store 
breakpoint or decrement one of the counters. When a counter on one of the load/store 
watchpoints expires, the load/store breakpoint is asserted. 


Watchpoints progress in the machine and are reported when they retire. Internal 
breakpoints progress in the machine until they reach the top of the history buffer when the 
machine branches to the breakpoint exception routine. So the breakpoint features can be 
used without restricting the software, the address of the load/store cycle that generated the 
load/store breakpoint is not stored in the data address register (DAR). In a load/store 
breakpoint, the address of the load/store cycle that generated the breakpoint is stored in the 
breakpoint address register (BAR). There are many types of internal watchpoints and 
breakpoints: 


e Four |-Address Comparators Supporting Equal, Not Equal, Greater Than, and Less 
Than. 


e Two L-Address Comparators Supporting Equal, Not Equal, Greater Than, and Less 
Than. 


° Two L-Data Comparators Supporting Equal, Not Equal, Greater Than, and Less Than. 
¢ No Internal Breakpoint or Watchpoint Support for Unaligned Words and Half-Words. 


e The L-Data Comparators Can Be Programmed to Treat Fixed-Point Numbers as 
Signed or Unsigned Values. 7 


~¢ Combined Comparator Pairs to Detect In and Out of Range Conditions, Including Either 
_ Signed or Unsigned Values On the L- Data. 


e A Programmable AND-OR Logic Structure Between the Four Instruction Comparators 
Results in Five Outputs, Four Instruction Watchpoints, and One Instruction Breakpoint. 


e A Programmable AND-OR Logic Structure Between the Four Instruction Watchpoints 
and the Four Load/Store Comparators Results in Three Outputs, Two Load/Store 
Watchpoints, and One Load/Store Breakpoint. | 


e Five Watchpoint Pins, Three For the Instruction and Two For the Load/Store. 


e Two Dedicated 16-Bit Down Counters. Each Can Be Programmed to Count Either an 
Instruction Watchpoint or a Load/Store Watchpoint. Only Architecturally Executed 
Events are Counted. 


e¢ On-The-Fly Trap Enable Programming of the Different Internal Breakpoints Using the 
Serial Interface of the Development Port. Software Control Is Also Available. 


e Watchpoints Do Not Change the Timing of the Machine. 


e Internal Breakpoints and Watchpoints Are Detected on the Instruction During 
Instruction Fetch. | 


e Internal Breakpoints and Watchpoints Are Detected on the Load/Store During Load/ 
Store Bus Cycles. 


e Instruction and Load/Store Breakpoints and Watchpoints Are Handled on Retirement 
and Then Reported. 
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e Breakpoints and Watchpoints on Recovered Instructions (As a Result of Exceptions, 
Interrupts, or Miss Peon) Are Not Reported and Do Not cilia the une of the 
Machine. 


e Instructions with Instruction Breakpoints Are Not Executed. The Machine Branches to 
the Breakpoint Exception Routine Before it Executes the Instruction. 


e Instructions with Load/Store Breakpoints Are Executed. The Machine Branches to the 
Breakpoint Exception Routine After it Executes the Instruction. ane Address oO} the” 
Access is Placed in the Breakpoint Address Register. 3 


¢ Load/Store Multiple and String Instructions with Load/Store Breakpoints First Finish’ 
Execution and Then the Machine Branches to the Breakpoint Exception Routine. | 


e Load/Store Data Compare is Made On the Load/Store, After Swap in Store Accesses 
and Before Swap in Load Accesses (As the Data Appears on the Bus). 


¢ Internal Breakpoints Operate with a Context-Dependent Filter. 
¢ Both “go to x” and “continue” Working Modes are Supported for Instruction Breakpoints. 


20.3.1.1 RESTRICTIONS. There are times when the same watchpoint can be detected 
more than once during the execution of a single instruction. For example, a load/store 
waitchpoint detected on more than one transfer when executing load/store multiple/string or 
load/store watchpoint detected on more than one byte when working in byte mode. In these 
cases only one watchpoint of the same type is reported for a single instruction. Similarly, 
only one watchpoint of the same type can be counted in the counters for a single instruction. 
Since watchpoint events are reported when the instruction that caused the event retires 
(more than one instruction can retire from the machine in a single clock), ensuing events can 
be reported in the same clock. Moreover, if the same event is detected on more than one 
instruction (tight loops or range detection) can just be reported once. The internal counters 
count correctly | in these cases. 


20.3.1.2 BYTE AND HALF-WORD WORKING MODES. You can use watchpoints and 
breakpoints to detect matches on bytes and half-words when the byte/half-word is accessed 
in a load/store instruction of larger data widths. For example, when loading a table of bytes 
using a series of load word instructions.) To use this feature in word mode, you should write 
the required match value to the correct half-word of the data comparator and to the mask in 
the L-data comparator. If you prefer to break on bytes, the byte mask for each L-comparator 
and the bytes to be matched must be written in the data comparator. 


Since bytes and half-words can be accessed using a larger data width instruction, it is | 
impossible for you to predict the exact value of the L-address lines when the requested byte/ 
half-word is accessed. If the matched byte is byte 2 of the word and is accessed using a load 
word instruction, the L-address value will be of the word (byte 0). Therefore, the core masks 
the two least-significant bits of the L-address comparators whenever a word access is 
performed and the least-significant bits whenever a half-word access is performed. Address 
range is only supported when aligned according to the access size. 
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Byte Working Mode Example 


Data size: Byte. 
Address: 0x00000003. 
Data value: Greater than 0x07 and less than Ox0Oc. 


Programming options: : 
One L-address comparator = 0x00000003 and program for equal. | 
One L-data comparator = 0x00000007 and program for greater than. 
One L-data comparator = 0x0000000c and program for less than. 
CGBMSK and CHBMSK fields of the LCTRL1 = Oxe. 

Both L-data comparators program to byte mode. 


Result: 


The event will be correctly detected, regardless of the load/store instruction the 
compiler chooses for this access. 


Half-Word Working Mode Example 1 
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Data size: Half-word. | | 
Address: Greater than 0xO0000000 and less than 0x0O000000c. 
Data value: Greater than 0x4e204e20 and less than 0x9c409c40. 





Programming option: 

One L-address comparator = Ox00000000 and program for greater than. 
One L-address comparator = 0x0000000c and program for less than. 
One L-data comparator = 0x4e204e20 and program for greater than. 
One L-data comparator = 0x9c409c40 and program for less than. 
CGBMSK and CHBMSK fields of the LCTRL1 = Oxe. 

Both L-data comparators program to half-word mode. 


Result: 


The event will be correctly detected as long as the compiler does not use a 
load/store instruction with data size of byte. 
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Half-Word Working Mode Example 2 


Data size: Half-word. : 
Address: Greater than or equal to OxO0000002 and less than 0x00000006e. 
Data value: Greater than 0x4e204e20 and less than 0x9c409c40. 


Programming option: 

One L-address comparator = Ox00000001 and program for sioutet than. 
One L-address comparator = 0x0000000e and program for less than. 
One L-data comparator = 0x4e204e20 and program for greater than. 
One L-data comparator = 0x9c409c40 and program for less than. 
CGBMSK and CHBMSK fields of the LCTRL1 = Oxe. 

Both L-data comparators program to half-word or word mode. 


Result: | | 

The event will be correctly detected if the compiler chooses a nacsicrs instruction with 
data size of half-word. If the compiler chooses load/store instructions with data size 
greater than half-word (word, multiple), there might be some false detections. 


This example uses Figure 20-2 to show the possible false detects that should be ignored by 
the software that handles me breakpoints. 


POSSIBLE FALSE DETECT ON THESE HALF-WORDS WHEN USING WORD/MULTIPLE 


~ 0X00000000 
0x00000004 
0x00000008 
0X0000000C 
0X00000010 





Figure 20-2. Example 2 False Detect on Watchpoint/Breakpoint 


20.3.1.3 CONTEXT-DEPENDENT FILTER. The core can only be programmed to 
recognize internal breakpoints when the MSR, bit is set or to always recognize internal 
breakpoints. When it is programmed only to recognize internal breakpoints or when 
MSR, = 1, all parts of the code can be debugged, except when the save and restore 
register 0 (SRRO), save and restore register 1 (SRR1), data address register (DAR), and 
data storage interrupt status register (DSISR) are busy and MSR», = 0. 
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When the core is programmed to recognize internal breakpoints, it is possible to debug all 
parts of the code. However, if an internal breakpoint is recognized when MSR, = 0 
(registers SRRO and SRR1 are busy), the machine enters into a nonrestartable state. For 
more information refer to Section 6.3.4.1 Restartability After An Interrupt. When working 
in the masked mode all internal breakpoints detected when MSR, =0 are lost and detected 
watchpoints are not counted by the debug counters. Detected watchpoints are always 
reported on the external pins, regardless of the value of the MSRa, bit. 


The core defaults to masked mode after reset. It is input in the nonmasked mode by setting 
the BRKNOMSK bit in the LCTRL2 register. The BRKNOMSK bit controls all internal 
breakpoints (I-breakpoints and L-breakpoints). See Section 20.6.2.7 Load/Store Support 
AND-OR Control Register for more information. 


20.3.1.4 IGNORE FIRST MATCH OPTION. To facilitate the debugger utilities of “continue” 
and “go from x”, the ignore first match option is supported for the instruction breakpoints. 
When an instruction breakpoint is first enabled, the first instruction will not cause an 
instruction breakpoint if the IFM bit in the instruction support control (ICTRL) register is set. 
This is used for “continue” utilities. When IFM is clear, every matched instruction can cause 
an instruction breakpoint. This is used for “go from x”. The IFM bit is set by the software and 
cleared by the hardware after the first instruction breakpoint, the match is ignored. Load/ 
store breakpoints and all counter-generated breakpoints (instruction and load/store) are 
unaffected by this mode. 


20.3.1.5 GENERATING COMPARE TYPES. Using the four compare types—equal to, not 
equal to, greater than, and less than—it is possible to generate two additional compare 


types: 
e Greater than or equal to 
e Less than or equal to 


Generating the greater than or equal to compare type can be accomplished by using the 
greater than compare type and programming the comparator to the value in question 
minus 1. Likewise, generating the less than or equal to compare type can be accomplished 
by using the less than compare type and programming the comparator to the value in 
question plus 1. Notice that this method does not work for the following boundary cases: 


e Less than or equal to the largest unsigned number (1111...1) 
e Greater than or equal to the smallest unsigned number (0000...0) 


e Less than or equal to the maximum positive number when in signed mode (0111...1) 

e Greater than or equal to the maximum negative number when in signed mode (1000...) 
These boundary cases do not require special support because they are considered ‘always 
true’. They can be programmed using the ignore option of the load/store watchpoint 


programming. See Section 20.6.2.7 Load/Store Support AND-OR Control Register for 
more information. 
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20.3.2 Basic Operation | 


20.3.2.1 INSTRUCTION SUPPORT. There are four instruction address comparators (A, B, 
C, and D). Each one is.30 bits long and generates two output events—equal to and less 
than. These signals generate one of four events—equal to, not equal to, greater than, or less 
than. The instruction watchpoints and breakpoint are generated using these events 
according to your programming. Using the OR option enables “out of range” detect. 


~ COMPARE TYPE 


CONTROL BITS 
COMPARE 


TYPE 
LOGIC 






- WATCHPOINT 0 












A 
EQ : 
COMPARE | | | 
COMPARATOR TYPE = WATCHPOINT 1 
B LT (A&B) 
LOGIC 
| (A1B) 
cf - WATCHPOINT 2 
a . 
ui % 
Lu 
(>) 
= D 
COMPARE i - WATCHPOINT:3 
TYPE tu 
D 
LOGIC s8D) 
(C 1D) - BREAKPOINT 





COMPARE 
TYPE 


LOGIC 





| Figure 20-3. Instruction Support General Structure 
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Table 20-4. Instruction Watchpoints Programming Options 


| NAME | DESCRIPTION PROGRAMMING OPTIONS 
IWO First instruction watchpoint Comparator A 
Comparators (A & B) 
Iw1 Second instruction watchpoint Comparator B 
Comparator (A | B) 







Third instruction watchpoint Comparator C 
Comparators (C & D) 
Fourth instruction watchpoint Comparator D 
Comparator (C | D) 


20.3.2.2 LOAD/STORE SUPPORT. There are two load/store address comparators E and 
F that compare the 32 address bits and the cycle’s attributes (read/write). The two 
least-significant bits are masked ignored whenever a word is accessed and the 
least-significant bit is masked whenever a half-word is accessed. Each comparator 
generates two output signals—equal to and less than. These signals generate one of four 
events from each comparator—equal to, not equal to, greater than, or less than. For more 
information, refer to Section 20.3.1.2 Byte And Half-Word Working Modes. 





There are two load/store data comparators G and H that are 32 bits wide and can be 
programmed to treat numbers as signed or unsigned values. Each data comparator 
operates as four independent byte comparators that have a mask bit and generate two 
output signals—equal to and less than (if the mask bit is not set.) Therefore, each 32-bit 
comparator has eight output signals. These signals generate the “equal to and less than” 
signals according to the compare size that you program (byte, half-word, word). When 
operating in byte mode, all signals. are significant. In half-word mode only four signals from 
each comparator are significant and in word mode only two signals are significant. In half- 
word mode only four signals from each comparator are significant, and in word mode only 
two signals are significant. 


One of the following four match events are generated by the equal to and less than 
signals—equal to, not equal to, greater than, or less than—depending on the programmed 
compare type. Therefore, from the two 32-bit comparators, eight match indications are 
generated—Gmatch[0:3] and Hmatch[0:3]. According to the lower bits of the address and 
the size of the cycle, only match indications detected on bytes with valid information are 
validated. The rest are negated. If the executed cycle has a smaller size than the compare 
size (a byte access when the compare size is word or half-word), no match indication will be 
asserted. Using the match indication signals, four load/store data events are generated as 
shown in Table 20-5. : 7 
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Table 20-5. Load/Store Data Events 







EVENT NAME 7 EVENT FUNCTION 





G (GmatchO.! Gmatch1 | Gmatch2 | Gmatch3) 


(HmatchO | Hmatch1 | Hmatch2 | Hmatch3) 








(G & H) ((GmatchO & Hmatch0) | (Gmatch1 & Hmatch1) | (Gmatch2 & Hmatch2) | (Gmatch3 & Hmatch3)) 
(GIA) 
NOTE: & denotes a logical AND, but | denotes a logical OR. 


((GmatchO | Hmatch0) | (Gmatch1 | Hmatch1) | (Gmatch2 | Hmatch2) | (Gmatch3 | Hmatch3)) 





The four load/store data events, combined with the match events of the load/store address 
comparators and the instruction watchpoints, are used to generate the load/store 
watchpoints and breakpoint according to your programming. 


@ 


Table 20-6. Load/Store Watchpoints Programming Options 


DESCRIPTION l-ADDRESS EVENT L-ADDRESS EVENT L-DATA EVENT | 
PROGRAMMING PROGRAMMING PROGRAMMING 
OPTIONS OPTIONS OPTIONS 


~ LNAINdO1SA3G: 


First Load/Store IWO, IW1, IW2, IWS, Comparator E | Comparator G 
Watchpoint Ignore I-address events Comparator F Comparator H 
Comparators (E & F) Comparators (G & H) 
Comparators (E | F) Comparators (G | H) 
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Ignore L-address events Ignore L-data Events 


Second Load/ IWO, IW1, IW2, IWS, Comparator E Comparator G 
Store Ignore l-address events Comparator F Comparator H 
Watchpoint | - Comparators (E & F) Comparators (G & H) 
Comparators (E | F) Comparators (G |! H) 
Ignore L-address events Ignore L-data Events 


When programming the load/store watchpoints to ignore L-address and L-data events, the 
instruction must be a load/store instruction to trigger the load/store watchpoint event. 


20.3.2.3 COUNTER SUPPORT. There are two 16-bit down counters that count one of the 
instruction watchpoints or one of the load/store watchpoints. Both generate the 
corresponding breakpoint. when they reach zero. When working in masked mode, the 
counters do not count detected watchpoints when MSR,, =0. Counter values are not 
predictable if they are counting watchpoints programmed on the instructions that alter the 
counters. Readings from the active counters must be synchronized by inserting a sync 
instruction before a read is performed. For details, refer to Section 20.3.1.2 Byte And Half- 
Word Working Modes. 
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Figure 20-4, Load/Store Support General Structure 
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Note: When programmed to count instruction watchpoints, the last instruction that 
decrements the counter to zero is treated like any other instruction breakpoint in 
the sense that it is not executed before the machine branches to the breakpoint 
exception routine. As a side effect of this behavior, the value of the counter inside 
the breakpoint exception routine equals 1 and not zero. When programmed to 
count load/store watchpoints, the last instruction that decrements the counter to 
zero is treated like any other load/store breakpoint in the sense that it is executed 
before the machine branches to the breakpoint exception routine. Therefore, the 
value of the counter inside the breakpoint exception routine equals zero. 


20.3.2.4 TRAP ENABLE PROGRAMMING. The trap enable bits can be programmed by 
regular software (only if MSRpp = 0) using the mtspr instruction or on-the-fly using the 
special development port interface. For more information, refer to Section 20.4.3.7 Trap 
Enable Mode. The value used by the breakpoint generation logic is the bit-wise OR of the 
software trap enable bits written using the mtspr instruction and the development port trap 
enable bits that are serially shifted using the development port. The software trap enable bits 
and development port trap enable bits can be read from the ICTRL and LCTRL2 registers 
using the mtspr instruction. For exact bit placement, refer to Section 20.6.2.7 Load/Store 
Support AND-OR Control Register and Section 20.6.2.5 Instruction Support Control 
Register. 


20.4 HARDWARE DEVELOPMENT SYSTEM INTERFACE 


When debugging an existing system it is sometimes helpful to be able to do so without 
making any changes. Although, in some cases it is not helpful and may even make it 
impossible to add load to the lines connected to the existing system. The development 
system interface of the core supports this configuration. ) 
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The development system interface of the core uses the development port, which is a 
dedicated serial port that does not need any of the regular system interfaces. System activity 
can be controlled from the development port when the core is in debug mode. The 
development port is a relatively inexpensive interface that allows the development system 
to operate in a lower frequency than the core’s frequency. It is also possible to debug the 
core using monitor debugger software. For more information, refer to 

Section 20.5 Software Monitor Debugger. 


In debug mode, the core fetches all instructions from the development port. Data can be 
read from or written to the development port. This allows memory and registers to be read 
and modified by a development tool (emulator) connected to the development port. For 
protection purposes two possible working modes are defined—debug mode enable and 
debug mode disable. These working modes are only selected during reset. For details, refer 
to Section 20.4.2.1 Debug Mode Enable vs. Debug Mode Disable. 
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You can work in debug mode directly out of reset or the core can be programmed to enter 
into the debug mode as a result of a predefined sequence of events. These events can be 
any interrupt or exception in the core system (including the internal breakpoints) in addition 
to two levels of development port requests and one peripheral breakpoint request generated 
internally and externally. Each of these can be programmed as a regular interrupt that 
causes the machine to branch to its interrupt vector or as a special interrupt that causes 
debug mode entry. When in debug mode, the rfi instruction returns the machine to its 
regular work mode. The relationship between debug mode logic and the rest of the core is 
illustrated in the following figure. 


EXT 
32. INTERNAL ae 
BUS 
VFLS, 
FRZ 
CONTROL LOGIC 
DEVELOPMENT 
PORT SUPPORT 
BKPT. TE TECR DPDR LOGIC 

> DSDO 





Figure 20-5. Relationship Between the CPU and Debug Mode 


The development port provides a full-duplex serial interface for communications between 
the internal development support logic of the core and an external development tool. The 
development port can operate in two working modes—trap enable mode and debug mode. 
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20.4.1 Trap Enable Mode 


The trap enable mode allows the following incidents to transfer control into the core internal 
development support logic. 


An instruction trap enable signal is used to program the instruction breakpoint 
on-the-fly. 


A load/store trap enable signal is used to program the load/store breakpoint on-the- ‘ily. 
A nonmaskable breakpoint is used to assert the nonmaskable external breakpoint. 

A maskable breakpoint is used to assert the maskable external breakpoint. 

A VSYNC control code is used to assert and negate VSYNC operation. 


In debug mode, the development port also controls the debug mode features of the core. 
For more details, refer to Section 20.4.3 The Development Interface Port. 


20.4.2 Debug Mode 


Debug mode provides the development system with the following functions: 


Controls and maintains all circumstances of processor execution. 


The development port can force the core to enter debug mode even when the external 
interrupts are disabled. 


Debug mode can be entered immediately out of reset, thus allowing you to debug a 
system without ROM. 


The events that cause the machine to enter into debug mode can be selectively defined 
through an enable register. 


Contains a cause register that indicates why debug mode is entered. 


After entering debug mode, program execution continues at the location where it first 
entered debug mode. 


All instructions are fetched from the development port, while load/store accesses are 
performed on the real system memory in debug mode. 


A simple method is provided for memory dump and load via the data register of the 
development port that is accessed with mtspr and mfspr. 


The processor enters the privileged state (MSRpp =0) in debug mode, thus allowing 
execution of any instruction and access to any storage location. 


An OR signal of all interrupt cause register bits enables the development port to detect 
pending events while already in debug mode. For example, the development port can 
detect a eerug mode access to nonexisting memory space. 
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Figure 20-6 illustrates the debug mode logic implemented in the core. 
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Figure 20-6. Debug Mode Logic Implementation 
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20.4.2.1 DEBUG MODE ENABLE VS. DEBUG MODE DISABLE. For protection 
purposes, there are two possible working modes—debug mode enable and debug mode 
disable. These modes are selected once at reset. Debug mode is enabled by asserting the 
DSCK pin during reset and the state of this pin is sampled three clocks before SRESET 
negation. If the DSCK pin is sampled negated, debug mode is disabled until a subsequent 
reset that occurs when the DSCK pin is asserted. When debug mode is disabled, the internal 
watchpoint/breakpoint hardware is still operational and can be used by a software monitor 
program for debugging purposes. A timing diagram for the enabling debug mode is 
illustrated in Figure 20-7 








7 A Note: SRESET negation time depends on an external pull-up resistor, so any reference 
to SRESET negation time refers to the time the MPC823 releases SRESET. If 
the rise time of SRESET is long because of a large resistor, the setup time for 

the debug port signals should be adjusted accordingly. 





When debug mode is disabled, all development support registers are accessible when 
MSRpp =0 and can be used by the monitor debugger software. However, the processor 
never enters debug mode and the ICR and DER are only used to assert or negate the freeze 
signal. For more information on the software monitor debugger, refer to 

Section 20.5 Software Monitor Debugger. Only when the core is in debug mode, are all 
development support registers accessible. Therefore, the development system has full 
control of the core’s development support features. For more information, see Table 20-12. 


20.4.2.2 ENTERING DEBUG MODE. Debug mode entry can be the result of a number of 
events. All events have a programmable enable bit so you can selectively decide that the 
cause of debug mode entry as well as the events that require regular interrupt handling. 
Entering debug mode is possible immediately out of reset, thus allowing a system to be 
debugged without ROM. Specially programming the development port during reset makes 
this possible. If the DSCK pin is asserted during SRESET assertion and after SRESET 
negation, the processor will take a breakpoint exception and go directly to debug mode 
instead of fetching the reset vector. 
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DSCK ASSERTS HIGH WHILE SRESET ASSERTED TO ENABLE DEBUG MODE OPERATIO# 





DSCK ASSERTS HIGH FOLLOWING SRESET NEGATION TO ENABLE DEBUG MODE IMMEDIATELY: 


Figure 20-7. Debug Mode Reset Configuration Timing Diagram 
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To avoid entering debug mode after reset, the DSCK pin must be negated no later than 
seven clock cycles after SRESET negates to allow the processor to jump to the reset vector 
and begin normal execution. Entering debug mode immediately after reset, Bit 31 
(development port interrupt bit) of ICR is set. For details, refer to the timing diagram 
illustrated in Figure 20-7. 


When debug mode is disabled, all events result in regular interrupt handling. The internal 
freeze signal is asserted whenever an enabled event occurs, regardless of whether or not 
debug mode is enabled or disabled. The internal freeze signal is connected to all relevant 
internal modules. These modules can be programmed to stop all operations in response to 
the assertion of the freeze signal. For more information, refer to Section 20.5.1 Freeze 
Indication (FRZ). Furthermore, the freeze indication is negated when exiting the debug 
mode and Section 20.4.2.6 Exiting Debug Mode has more information on the issue. 


The following list of events can cause the core to enter debug mode. Each event results in 
debug mode entry if debug mode is enabled and the corresponding enable bit is set. The 
reset values of the enable bits allow debug mode features to be used even when debug 
enable mode (DER) is not programmed. For more information, see Section 20.6.3.2 Debug 
Enable Register. 


¢ System reset as a result of SRESET assertion 

¢ Checkstop | 

e Machine check interrupt 

° Implementation specific instruction TLB miss | 

¢ Implementation specific instruction TLB error 

e Implementation specific data TLB miss 

¢ Implementation specific data TLB error 

e External interrupt, recognized when MSRe_¢ =1 

e Alignment interrupt 

¢ Program interrupt 

e Floating-point unavailable interrupt 

¢ Decrementer interrupt, recognized when MSRe¢ =1 
e System call interrupt | 

e Trace asserted when in single or branch trace mode 
e Implementation dependent software emulation interrupt 


e Instruction breakpoint is recognized only when MSRap, =1 and when breakpoints are 
masked. When breakpoints are not masked, they are always recognized. 


e Load/store breakpoint is recognized only when MSR,y = 1 and when breakpoints are 
masked. When breakpoints are not masked, they are always recognized. 
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e Peripheral breakpoint from the development port generated by external modules are 
recognized only when MSRp, =1. : 


e Development port nonmaskable interrupt occurs as a result of a debug station request. 
Useful in some catastrophic events like an endless loop when MSR,, =0. As a result of 
this event, the machine can enter a nonrestartable state. 


The processor enters into the debug mode state when at least one of the bits in the ICR is 
set, the corresponding bit in the DER is enabled, and debug mode is enabled. When debug 
mode is enabled and an enabled event occurs, the processor waits until its pipeline is empty 
and then starts fetching the next instructions from the development port. For information on 
the exact value of the SRRO and SRR1 registers, refer to Section 7.3.7.3 Definitions. 
When the processor is in debug mode, the freeze indication is asserted, thus allowing any 
properly programmed peripheral to stop. The fact that the core is in debug mode is also 
broadcasted to the external world using the value b’11’ on the VFLS pins. The freeze signal 
can be asserted by the software when debug mode is disabled. The development port 
should read the value of the ICR to find out what causes debug mode entry. Reading the 
ICR clears all of its bits. 


20.4.2.3 CHECKSTOP STATE AND DEBUG MODE. The core enters checkstop state if 
the machine check interrupt is disabled (MSRye =0) and a machine check interrupt is 
detected. However, if a machine check interrupt is detected when MSRy_ =0, debug mode 
is enabled, the checkstop enable bit in the DER is set, and the core enters debug mode 
rather then the checkstop state. The various actions taken by the core when a machine 
check interrupt is detected are provided in the following table. 


Table 20-7. Checkstop State and Debug Mode 


ACTION PERFORMED BY THE CORE 
WHEN A MACHINE 
CHECK INTERRUPT IS DETECTED 





1. The checkstop enable bit of the DER register. 
2. The machine check interrupt enable bit of the DER register. 
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20.4.2.4 SAVING THE MACHINE STATE IN DEBUG MODE. If entering debug mode is 
the result of a load/store-type exception, the DAR and DSISR registers contain critical 
information. These two registers must be saved before any other operation is performed. 
Failing to save these registers can result in information loss if another load/store-type 
exception occurs inside the development software. Since exceptions are treated differently 
in debug mode, there is no need to save the SRRO and SRR registers. | 


20.4.2.5 RUNNING IN DEBUG MODE. When running in debug mode, all fetch cycles 
access the development port, regardless of the cycle’s actual address. All load/store cycles 
access the real memory system according to the cycle’s address. The data register of the 
development port is mapped as a special control register and is accessed using the mtspr 
and mfspr instructions, via special load/store cycles. 


Exceptions are treated differently in debug mode. When in debug mode, the ICR is updated 


when an exception is recognized by the event that caused the exception. A special error 
indication (ICR_OR) is asserted for one clock cycle to notify the development port that an 
exception has occurred. Execution then continues in debug mode without any change in the 
SRRO and SRRi1 registers. ICR_OR is asserted before the next fetch occurs so the 
development system can detect the excepting instruction. However, not all exceptions are 
recognizable in debug mode. Breakpoints and watchpoints are not generated by the 
hardware when in debug mode, regardless of the MSR, bit’s value. When entering debug 
mode, the MSR_, bit is cleared by the hardware, thus forcing the hardware to ignore external 
and decrementer interrupts. | 


WZ Caution: Setting the MSRe_- bit with the debug software in debug mode is strictly 
: | forbidden. 


This restriction is relevant because the external interrupt event is a level signal. Because the 
core only reports exceptions in debug mode and does not perform exception processing, the 


_ core hardware does not clear the MSR¢, bit. This event, if enabled, is then recognized on 
every clock. When the ICR_OR signal is asserted, the development station must search the 


ICR to find the event that caused the exception. Since the values in the SRRO and SRR1 
registers do not change if an exception is recognized in debug mode, they only change once 
when entering debug mode. However, it is not necessary to save the SRRO and SRR1 


~ registers when entering debug mode. 


20.4.2.6 EXITING DEBUG MODE. The rfi instruction is used to exit from debug mode and 
return to normal processor operation and negate the FRZ signal. The development system 
may monitor the FRZ signal or status to make sure the MPC823 is out of debug mode. It is 
the responsibility of the software to read the ICR before performing the rfi instruction. Failure 
to do so forces the core to immediately reenter debug mode and reassert the freeze signal 
if an asserted bit in the ICR register has a corresponding enable bit set in the DER register. 
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20.4.3 The Development Interface Port 


The development port provides a full-duplex serial interface for communications between 
the internal development support logic and an external development tool. The relationship 
of the development support logic to the rest of the core Is illustrated in Figure 20-5. Notice 
that the development port support logic is shown as a separate block for clarity. It will be 
implemented as part of the system interface unit module. The development interface port 
contains the four pins: 


¢ Development serial clock 

e Development serial data in 
e Development serial data out 
e Freeze 


20.4.3.1 DEVELOPMENT SERIAL CLOCK. The development serial clock (DSCK) pin is 
used to shift data into and out of the development interface port shift register. At the same 
time, the new most-significant bit of the shift register is presented to the development serial 
data out (DSDO) pin. Future references to the DSCK signal imply the internally 
synchronized value of the clock. The DSCK input must be driven either high or low at all 
times and it not allowed to float. With a resistor, a typical target environment would pull this 
input low. | 


The clock can be implemented as a free-running or gated clock. The shifting of data is 
controlled by the ready and start signals, so the clock does not need to be gated with the 
serial transmissions. The DSCK pin is used at reset to enable debug mode either 
immediately following reset or to enter debug mode driving an event. 


20.4.3.2 DEVELOPMENT SERIAL DATA IN. Data to be transferred into the development 
interface port shift register is presented to the development serial data in (DSDI) pin by 
external logic. When driven asynchronous with the system clock, the data presented to the 
DSDI pin must be stable at setup time before the rising edge of DSCK and at hold time after 
the rising edge of DSCK. When synchronously driven to the system clock, the data must be 
stable on DSDI or a setup time before system clock output (CLKOUT) rising edge and a hold 
time after the rising edge of CLKOUT. The DSDI pin is also used at reset to control the © 
overall chip configuration mode and determine the development port clock mode. Refer to 
Section 20.4.3.6 Development Port Serial Communication for more information. 


20.4.3.3 DEVELOPMENT SERIAL DATA OUT. The debug mode logic shifts data out of 
the development interface port shift register using the development serial data out (DSDO) 
pin. All transitions on DSDO are synchronous with DSCK or CLKOUT, depending on the 
clock mode. Data will be valid at setup time before the rising edge of the clock and remains 
valid at hold time after the rising edge of the clock. See Table 20-10 for details about DSDO 
data. | a 
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20.4.3.4 FREEZE. A freeze indication means that the processor is in debug mode and that 
normal processor execution of user code is frozen. The freeze state is indicated on the FRZ 
pin and is generated synchronous to the system clock. This indication can be used to halt 

any off-chip device while in debug mode and is a handshake between the debug tool and 

port. In addition to the FRZ pin, the freeze state is indicated by the value b11 on the VFLS 
pins. The internal freeze status can also be monitored through status in the data shifted out 
of the debug port. 
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Figure 20-8. Development Port/Background Development Mode 
: Connector Pinout Options , 


20.4.3.5 DEVELOPMENT INTERFACE PORT REGISTERS. The development interface 
port consists logically of three registers—development interface port instruction register, 
development interface port data register, and trap enable control register. However, these 
registers are physically implemented as two registers—the development interface port shift 
register and the trap enable control register. The development interface port shift register 
acts as both the DPIR and DPDR, depending on the operation being performed. It is also 
used as a temporary holding ee for data to be stored in the TECR. See Table 6-9 for 
more information. 


20.4.3.5.1 Development Interface Port Shift Register. The development interface port 
shift register (DPIR/DPDR) is a 35-bit shift register. Instructions and data are serially shifted 
into it from the DSDI using DSCK or CLKOUT as the shift clock, which depends on the 
debug port clock mode. For more information refer to Section 20.4.3.6 Development Port 
Serial Communication. 
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The instructions or data are then transferred in parallel to the core and TECR. When the 
processor enters debug mode it fetches instructions from the DPIR, which causes an access 
to the development interface port shift register. These instructions are serially loaded into 
the shift register from the DSDI using DSCK or CLKOUT as the shift clock. Similarly, data is 
transferred to the core. Data is shifted into the shift register and read by the processor when 
a “move from special-purpose register DPDR’” instruction is executed. Data is also parallel 
loaded into the development interface port shift register from the core by executing a “move 
to special-purpose register DPDR’” instruction. It is then serially shifted out to the DSDO pin 
using DSCK or CLKOUT as the shift clock. 


20.4.3.5.2 Trap Enable Control Register. The 9-bit trap enable control register (TECR) is 
loaded from the development interface port shift register. The contents of the control register 
drive the six trap enable signals, two breakpoint signals, and the VSYNC signal to the core. 
The transfer data to trap enable control register commands are used to force the appropriate 
bits to be transferred to this register. The trap enable control register is not accessed by the 
core, but supplies signals to the core. The trap enable bits, VSYNC bit, and the breakpoint 
bits of this register are loaded from the development interface port shift register as a result 
of trap enable mode transmissions. The trap enable bits are reflected in the ICTRL and 
LCTRL2 special registers. Refer to Section 20.6.2 Development Port Registers for more 
information on the support registers. 


20.4.3.5.3 Decoding the Development Interface Port Registers. The development 
interface port shift register is selected when the core accesses the DPIR or DPDR registers. 
Accesses to these two special-purpose registers occur in debug mode and appear on the 
internal bus as an address and the assertion of an address attribute signal indicating that a 
special-purpose register is being accessed. The DPIR is read by the core to fetch all 
instructions when in debug mode. The DPDR is read and written to transfer data between 
the core and external development tools. The DPIR and DPDR are pseudo-registers, so 
decoding either of these registers causes the development interface port shift register to be 
accessed. The debug mode logic knows whether the core is fetching instructions or reading 
or writing data. A sequence error is signaled to the external development tool when the core 
expected result and the GPR result do not match. An example os this would be when an 
instruction is received instead of the expected data. 


20.4.3.6 DEVELOPMENT PORT SERIAL COMMUNICATION. All serial transmissions 
are synchronous, with respect to the transmission clock. 


-20.4.3.6.1 Clock Mode Selection. With respect to CLKOUT, the transmission clock can 
either be synchronous or asynchronous. The development port has two methods that can 
be used to clock serial transmissions. The first method allows the transmission to occur 
without being externally synchronized to CLKOUT. In this mode, a serial clock DSCK must 
be supplied to the MPC823. The other communication method requires data to be externally 
synchronized with respect to CLKOUT. 
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The first clock mode is called asynchronous clocked since the input clock DSCK is 
asynchronous with respect to CLKOUT. To be sure that data on DSDI is sampled correctly, 
transitions on DSDI must meet all setup and hold times in respect to the rising edge of 


. DSCK. This clock mode allows communications with the port from a development tool that 


does not have access to the CLKOUT signal or has either a delayed or skewed CLKOUT 


signal. The timing diagram in Figure 20-9 illustrates serial communication sey nenroneus 
7 clocked pening: | . | 


The second clock mode is called evrchronous self- aed and does not require an input 
clock. Instead, the port is clocked by the system clock. The DSDI input is required to meet 
setup and hold time requirements, with respect to the rising edge of CLKOUT. The data rate 


for this mode is always the same as the system clock. The timing diagram in Figure 20-10 


illustrates serial communication synchronous self-clocked timing. The selection of clocked 


or self-clocked mode is made at reset. The state of the DSDI input is latched eight clocks 


after SRESET is negated. If it is latched low, asynchronous clocked mode is enabled. If it is 
latched high, then synchronous self-clocked mode is enabled. The timing diagram in 


' Figure 20-11 illustrates the clock mode selection following reset. 


Since DSDI is used to select the development port clock scheme, any transitions on DSDI 
during clock mode select must be prevented from being recognized as the start of a serial 
transmission. The port will not begin scanning for the START bit of a serial transmission until 
16 clocks after SRESET is negated. If DSDI is asserted 16 clocks after SRESET negates, 
the port waits until DSDI is negated before it starts scanning for the START bit. 


20.4.3.7: TRAP ENABLE MODE. When not in debug mode, the development port begins 
communicating by setting DSDO (the MSB of the 35-bit development interface port shift 
register) low to show that all activity related to the previous transmission is complete and 
that a new transmission can begin. The start of a serial transmission from an external 


development tool to the development port is signaled by a START bit. A MODE bit in the 
_ transmission defines it as either a trap enable mode or debug mode transmission. If the 
: MODE bit is set, the transmission will be 10 bits long and only seven data bits will be shifted 


into the shift register. These seven bits will be latched into the TECR. A control bit 
determines whether the data is latched into the TECR’s trap enable, VSYNC, or breakpoints 
bits. 


The development interface port shift register is 35 bits wide, but trap enable mode 
transmissions only use 10 of the 35 bits—start/ready, mode/status, control/status, and 
seven least-significant data bits. The encoding of data shifted into the olaoel interface 
port. oun —— is shown in 1 Table 20-8 and Table 20-9. 
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DEBUG PORT DETECTS THE “START” BIT ON DSDI AND FOLLOWS THE “READY? BIT 
WITH TWO STATUS BITS AND 7 OR 32 OUTPUT DATA BITS. 


DEVELOPMENT TOOL DRIVES THE “START” BIT ON DSDI (AFTER DETECTING THE “READY” BIT ON DSDO 
WHEN IN DEBUG MODE). THE “START BIT IS IMMEDIATELY FOLLOWED BY A MODE BIT AND A CONTROL 
BIT AND THEN 7 OR 32 INPUT DATA BITS. 

DEBUG PORT DRIVES THE “READY” BIT ONTO DSDO WHEN READY FOR A NEW TRANSMISSION. 


NOTE: DSCK AND DSDI TRANSITIONS ARE NOT REQUIRED TO BE SYNCHRONOUS WITH CLKOUT. 


Figure 20-9. Asynchronous Clocked Serial Communications Timing Diagram 
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DEBUG PORT DETECTS THE “START” BIT ON DSDI AND FOLLOWS THE “READY” 
BIT WITH TWO STATUS BITS AND 7 OR 32 OUTPUT DATA BITS. 


DEVELOPMENT TOOL DRIVES THE “START BIT ONTO DSDI (AFTER DETECTING THE “READY” BIT ON 
DSDO WHEN IN DEBUG MODE). THE “START” BIT IS IMMEDIATELY FOLLOWED BY A MODE BIT 
AND A CONTROL BIT AND THEN 7 OR 32 INPUT DATA BITS. 


DEBUG PORT DRIVES THE “READY” BIT ONTO DSDO WHEN THE CPU STARTS A READ OF DPIR OR DPDR. 


Figure 20-10. Synchronous Self-Clocked Serial Communications Timing Diagram 
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DSDI 


CLKEN 


DSDI NEGATES FOLLOWING SRESET NEGATION TO ENABLE CLOCKED MODE. 











THE INTERNAL CLOCK ENABLE SIGNAL ASSERTS 8 CLOCKS AFTER SRESET NEGATION IF 
DSDI IS NEGATED. THIS ENABLES CLOCKED MODE. 


FIRST START BIT DETECTED AFTER DSDI NEGATION (SELF-CLOCKED MODE). 


Figure 20-11. Enabling Clock Mode Following Reset Timing Diagram 
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Table 20-8. Trap Enable Data Shifted Into DPS Register 


START CONTROL | FIRST SECOND THIRD | FOURTH | FIRST | SECOND | VSYNC FUNCTION 
INSTRUCTION WATCHPOINT DATA WATCHPOINT 
TRAP ENABLES TRAP ENABLES 
1 : 0 = Disabled Transfer Data to 
1 = Enabled Trap Enable Control 
Register 


Table 20-9. DEBUG PORT Command Shifted Into the DPS Register 


lies a a 
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11111 Negate Maskable Breakpoint 





















02, 
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Assert Maskable Breakpoint 
Negate Nonmaskable Breakpoint 
Le Wes 11111 Assert Nonmaskable Breakpoint 


The watchpoint trap enable and VSYNC functions are described in 

Section 20.3 Generating Watchpoints And Breakpoints and Section 20.2 Program 
Flow Tracking. The DEBUG PORT command allows the development tool to either assert 
or negate breakpoint requests, reset the processor, or activate or deactivate the fast 
download procedure. Status out of the development interface port in the trap enable mode 
is shown in Table 20-10. 
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Table 20-10. Status/Data Shifted Out of DPS Register 
BITS 2-31 OR 2-6, 
DEPENDING ON THE INPUT 


READY | STATUS [0:1] FUNCTION 
| BIT 0 BIT 1 
| MODE 


ope [o ona 
To [ape 
E 


NOTE: For freeze status, 0 means the core is in normal mode and 1 means the core is in debug mode. For download 
status, O means the download is in progress and 1 means the core is in normal mode. 









Download 
Procedure 


Freeze 
Status 
















n 
Progress 


In trap enable mode the “Valid Data from CPU” and “CPU Interrupt” status cannot occur. Out 
of debug mode, the sequencing error encoding indicates that the transmission from the 
external development tool was a debug mode transmission. When a sequencing error 
occurs, the development interface port ignores the data shifted in while the sequencing error 
is shifting out and being treated as a no operation (NOP) function. The null output encoding 
indicates that the previous transmission did not have any associated errors. Out of debug 
mode, ready will be asserted at the end of each transmission. If debug mode is not enabled 
and transmission errors are guaranteed not to occur, the status output is not needed. 
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20.4.3.8 DEBUG MODE. In debug mode the development interface port starts 
communicating by setting DSDO low to show that the core is trying to read an instruction 
from the DPIR or data from the DPDR. When the core writes data to the port to be shifted 
out, the READY bit is not set. The port waits for the core to read the next instruction before 
asserting ready. This allows duplex operation of the serial port while allowing the port to 
control all transmissions from the external development tool. After detecting this ready 
status, the external development tool begins the transmitting the development interface port 
with a START bit (logic high) on the DSDI pin. | 


In debug mode the 35 bits of the development interface port shift register are interpreted as 
a START/READY bit, a MODE/STATUS bit, a CONTROL/STATUS bit, and 32 bits of data. 
All instructions and data for the core are transmitted with the mode bit cleared, thus 
indicating a 32-bit DATA field. The encoding of data shifted into the development interface 
port shift register through the DSDI pin is shown in Table 20-11. 
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Table 20-11. Debug Instructions/Data Shifted Into the DPS Register 


INSTRUCTION / DATA (32 BITS) 


CONTROL 
BITS 0:6. |. BITS 7:31 
CPU Instruction Transfer Instruction to Core 
a CPU Data ‘Transfer Data to Core 


Trap Enable Not Exist Transfer Data to Trap Enable 
Bits | eh Control Register 
0011111. Not Exist Negate prear eon Requests 


NOTE: See Table 20-8 for details on trap enable bits and Table 20-9 for details on debug port commands. 













FUNCTION 







to Core 
_ NOP 


’ 





All transmissions from the debug port on DSDO begin with a zero or ready bit. This indicates 
that the core is trying to read an instruction or data from the port. The external development 
tool waits until it sees DSDO go low before it starts sending the next transmission. The 

control bit differentiates between instructions and data that allow the development interface 


_ port to detect an instruction that was entered when the core was expecting data and vice 
versa. If this occurs, a sequence error indication is shifted out in the next serial transmission. 
_ The trap enable function allows the development interface port to transfer data to the trap 


enable control register. The DEBUG PORT command allows the development tool to either 
negate breakpoint requests, reset the processor, or activate or deactivate the fast download 
procedure. The NOP function provides a null operation to use when there is data or a- 
response to be shifted out of the data register. The next appropriate instruction or command 
will be determined by the value of the response or data shifted out. i 7 | 


The encoding of data shifted out of the development interface port shift register in debug 
mode is the same as for trap enable mode, as shown in Table 20-10. The valid data 
encoding is used when data has been transferred from the core to the development interface 
port shift register. This results when an instruction to move the contents of a | 
general-purpose register to the DPDR occurs. The valid data encoding has the highest — 
priority of all status outputs and will be reported even if an interrupt occurs at the same time. 
Since it is not possible for a sequencing error to occur that has valid data, there is no priority 
conflict with the sequencing error status. Also, any interrupt that is recognized at the same 
time that there is valid data, is not related to the execution of an instruction. Therefore, a 


valid data status will be output and the interrupt status will be saved for the next 


transmission. 
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The sequencing error encoding indicates that the external development tool inputs are not 
what the development interface port and/or the core was nee: There are two possible 
causes of this error: 


e The processor was trying to read instructions and data was shifted into the 
development interface port. 


e The processor was trying to read data and an instruction was shifted into the 
development interface port. 


Nonetheless, the port terminates the read cycle with a bus error. In turn, this bus error 
causes the core to signal that an interrupt exception has occurred. Since a status of 
sequencing error is of higher priority than an exception, the port reports the sequencing error 
first and the core interrupt on the next transmission. The development interface port ignores 
the command, instruction, or data shifted in while the sequencing error or core interrupt is 
shifted out. The next transmission, after all error status is reported to the port, should be 
either a new instruction, trap enable, or command. 


The interrupt encoding that has occurred indicates that the core encountered an interrupt 
while executing the previous instruction in debug mode. Interrupts can occur as the result of 
instruction execution (such as unimplemented opcode or arithmetic error), because of a 
memory access fault, or from an unmasked external interrupt. When an interrupt occurs, the 
development interface port ignores the command, instruction, or data shifted in while the 
interrupt encoding was shifting out. The next transmission to the port should be a new 
instruction, trap enable, or DEBUG PORT command. Finally, the null encoding indicates 
that no data has been transferred from the core to the development interface port shift 
register. 


The fast download procedure is used to download a block of data from the debug tool into 
the system memory. This procedure can be accomplished by repeating the following ~ 
sequence of transactions from the development tool to the debug port for the number of data 
words to be downloaded. 


INIT:Save RX, RY 
RY <- Memory Block address- 4 


repeat:mfspr RX, DPDR 

DATA word to be moved to memory 
stwu RX, 0x4 (RY) 

until here 


Restore RA, RY 


Figure 20-12. Download Procedure Code Example 
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For large blocks of data, this sequence can take a significant amount of time to complete. 
Using the fast download procedure of the debug port will reduce the time by eliminating the 
need to transfer the instructions in the loop to the debug port. The only transactions needed 
are those used to transfer the data to be placed in the system memory. Figure 20-13 and 
Figure 20-14 illustrate the benefit of using the fast download procedure. 


EXTERNAL 
TRANSACTION 


INTERNAL 
ACTIVITY 





Figure 20-13. Slow Download Procedure Loop 





EXTERNAL 
TRANSACTION 


INTERNAL ~ 
ACTIVITY 





Figure 20-14. Fast Download Procedure Loop 


The sequence of the instructions used in the fast download procedure is illustrated in 
Figure 20-12, with RX = r31 and RY = r30. This sequence is repeated infinitely until the END 
DOWNLOAD PROCEDURE command is issued to the debug port. The internal 
general-purpose register 31 is used for temporary storage of the data value. Before 
beginning the fast download procedure by issuing the START DOWNLOAD PROCEDURE 
command, the value (of the first memory block address -4) must be written into the 
general-purpose register 30. To end the download procedure, an END DOWNLOAD 
PROCEDURE command should be issued to the debug port and the development tool will 
send an additional data transaction. This data word will not be placed into the system 
memory, but it is needed to stop the procedure. 


20.5 SOFTWARE MONITOR DEBUGGER 


When in debug mode disable, a software monitor debugger can use all of the development 
support features defined in the core. When debug mode is disabled, all events result in 
regular interrupt handling in which the processor resumes execution in the corresponding 
interrupt handler. The ICR and DER only influence the assertion and negation of the freeze 
signal. 
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20.5.1 Freeze Indication (FRZ) 


The internal freeze signal is connected to all relevant internal modules that can be 
programmed to stop all operations in response to freeze signal assertion. To enable a 
software monitor debugger to signal that the debug software is now executed, the internal 
freeze signal can be asserted or negated when debug mode is disabled. 


Assertion of the freeze signal is broadcasted to the external world over FRZ. Asserting and 
negating the freeze signal when in disabled debug mode is controlled by the ICR and DER, 
as illustrated in Figure 20-6. 


To assert the FRZ signal, the software must be programmed to use the relevant bits in the 
DER. To negate the FRZ signal the software must read the ICR to clear it and perform an 
rfi instruction. If the [CR is not cleared before the rfi instruction is performed, the FRZ signal 
_is not negated. Therefore, nested exception tracing can be supported by the software 
monitor debugger without affecting the value of the FRZ signal. Only before the last rfi 
instruction does the software need to clear the ICR. This process enables the software to 
accurately control FRZ assertion or negation. 


20.6 PROGRAMMING THE DEVELOPMENT PORT REGISTERS 


Normally, the development port registers reside in the control register space and can be 
accessed using the mtspr and mfspr instructions. They also reside in the memory map I/o 
to be accessed by the Id and st instructions. The addresses of these registers are in 
Table 6-9. 


20.6.1 Protecting the Development Port Registers 


The development support registers are protected as shown in the following table. Take note 
of the ICR and DPDR registers’ special behavior. 







Table 20-12. Development Support Register Protection | 
DEBUG 
MODE 


OPERATION IN DEBUG RESULT 
MODE 
ENABLE 


Read Register ae ee A read is performed and when reading ICR, it is also 
cleared. 
ae ee A bar is performed and when reading ICR, it is not 
cleared 


a feacll is performed and when reading ICR, it is also 
cleared 













A read is not performed, a program interrupt is 
generated, and when reading ICR, it is not cleared. 








Write Register A write is Polo a write to ICR is ignored, and a 


write to DPDR is ignored. 


A write is performed and a write to ICR is ignored. 


A write is not performed, but a program interrupt is 
generated. 
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20.6.2 Development Port Registers 


20.6.2.1 COMPARATOR A-D VALUE REGISTERS. The comparator A-D value 
CMPA-D) registers contain the address to be compared to the instruction address for 
generating an instruction watchpoint. These registers have an undefined reset value. 
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ICMPV—Instruction Comparison Value 
This field represents the address bits to be compared to the instruction address. 


Bits 30-—31—Reserved 
These bits are reserved and should be set to 0. 
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20.6.2.2 COMPARATOR E-F VALUE REGISTERS. The comparator E-F value (CMPE-F) 
registers contain the address to be compared to the load/store address for generating a 
load/store watchpoint. These registers have an undefined reset value. 


CMPE-F 





152, 153 


NOTE: X = “Don’t Care”. 
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LCMPV—Load/Store Comparison Value 
This field is the address bits to be compared to the load/store address. 





20.6.2.3 COMPARATOR G-H VALUE REGISTERS. The comparator G-H value 
(CMPG-H) registers contain the data to be compared to the translation data. These registers 
have an undefined reset value. 


CMPG-H 





NOTE: X = “Don’t Care”. 
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DCMPV—Data Comparison Value 
This field represents data to be compared to the translation data. 


20.6.2.4 BREAKPOINT ADDRESS REGISTER. The breakpoint address (BAR) register 
contains the address of the transaction or the instruction that causes the breakpoint. This 


register has an undefined reset value. 


BAR 








NOTE: X= “Don’t Care”. 


BARV—Breakpoint Address Register Value - 2 
The field represents the value to be compared to the breakpoint. 
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20.6.2.5 INSTRUCTION SUPPORT CONTROL REGISTER. The instruction support 
control (ICTRL) register controls instruction operation. 


ICTRL 


SIWOEN |} SIW1EN | SIW2EN | SIWSEN | DIWOEN | DIW1EN DIW2EN DIWSEN 
Lae ae ae a ee 


158 
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CTA—Compare Type of Comparator A 


Oxx = Not active (reset value). 
100 = Equal to. 

101 = Less than. 

110 = Greater than. 

111 = Not equal to. 





@ 


CTB—Compare Type of Comparator B 


Oxx = Not active (reset value). 
100 = Equal to. 

101 = Less than. 

110 = Greater than. 

111 = Not equal to. 


CTC—Compare Type of Comparator C 


Oxx = Not active (reset value). 
100 = Equal to. 

101 = Less than. 

110 = Greater than. 

111 = Not equal to. 


CTD—Compare Type of Comparator D 
Oxx = Not active (reset value). 
100 = Equal to. 
101 = Less than. 
110 = Greater than. 
111 = Not equal to. 
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IWO0—Instruction Watchpoint 0 
Ox = Not active (reset value). 
10 = Match from comparator A. 
11 = Match from comparators A & B. 


IW1—Instruction Watchpoint 1 
Ox = Not active (reset value). 
10 = Match from comparator A. 
11 = Match from comparators A | B. 


{W2—Instruction Watchpoint 2 


Ox = Not active (reset value). 
10 = Match from comparator C. — 
11 = Match from comparators C & D. 


_ |W3—Instruction Watchpoint 3 


Ox = Not active (reset value). 
10 = Match from comparator C. 
11 = Match from comparators C | D. 


SIWOEN—Software Instruction Watchpoint Trap Enable 0 


0 = Trap disabled (reset value). 
1 = Trap enabled. 


SIW1EN—Software Instruction Watchpoint Trap Enable 1 


O= Trap disabled (reset value). 
1 = Trap enabled. 


SIW2EN—Software Instruction Watchpoint Trap Enable 2 


O= Trap disabled (reset value). 
1 = Trap enabled. 


SIW3EN—Software Instruction Watchpoint Trap Enable 3 


0 = Trap disabled (reset value). 
1 = Trap enabled. 


DIWOEN—Development Port Instruction Watchpoint Trap Enable 0 
This is a read-only bit. 


0 = Trap disabled (reset value). 
1 = Trap enabled. 


DIW1EN—Development Port Instruction Watchpoint Trap Enable 1 
This is a read-only bit. 


0 = Trap disabled (reset value). 
1 = Trap enabled. 
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DIW2EN—Development Port Instruction Watchpoint Trap Enable 2 
This is a read-only bit. 


O= Trap disabled (reset value). 
1 = Trap enabled. 


DIW3EN—Development Port Instruction Watchpoint Trap Enable 3 
This is a read-only bit. 


O= Trap disabled (reset value). 
1 = Trap enabled. 


IF M—lignore First Match Only for Instruction Breakpoints 


0 = Do not ignore first match. Used for “Go To x” (reset value). 
1 = Ignore first match. Used for “Continue”. 


ISCT_SER—lInstruction Fetch Show Cycle and Core Serialize Control 


This field defines one of several performance versus visibility options for core behavior. 111 
is the preferred encoding for normal operation. Changing the instruction show cycle 
programming starts to take effect only from the second instruction after the actual mtspr 
instruction to ICTRL. 


000 = Core is fully serialized and show cycle will be performed for all fetched 
instructions (reset value). Has a reset value of OxO0000000. 

001 = Core is fully serialized and show cycle will be performed for all changes in the 
program flow. 

010 = Core is fully serialized and show cycle will be performed for all indirect changes 
in the program flow. 

011 = Core is fully serialized and no show cycles will be performed for fetched 
instructions. | 

100 = Illegal. 

101 = Core is not serialized (normal mode) and show cycle will be performed for all 
changes in the program flow. If the fetch of the target of a direct branch is aborted 
by the core, the target is not always visible on the external pins. This does not 
affect program trace. | 

110 = Core is not serialized (normal mode) and show cycle will be performed for all 
indirect changes in the program flow. 

111 = Core is not serialized (normal mode) and no show cycles will be panoimes for 
fetched instructions. 


For more information, see Section 20.2.2 Controlling Instruction Fetch Show Cycles. 
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20.6.2.6 LOAD/STORE SUPPORT COMPARATORS CONTROL REGISTER. The 


load/store support comparators contro! (LCTRL1) register controls the load/store breakpoint 
and watchpoint operation. 


LCTRL1 


SUSG “SUSH CGBMSK CHBMSK RESERVED 
sk AE, Se RE: a ES 
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CTE—Compare Type, Comparator E 


Oxx = Not active (reset value). 
100 = Equal to. — 

101 = Less than. 

110 = Greater than. 

111 = Not equal to. 
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CTF—Compare Type, Comparator F 


Oxx = Not active (reset value). 
100 = Equal to. 

101 = Less than. 

110 = Greater than. 

111 = Not equal to. 


CTG—Compare Type, Comparator G 
Oxx = Not active (reset value). 
100 = Equal to. 
101 = Less than. 
110 = Greater than. 
111 = Not equal to. 
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CTH—Compare Type, Comparator H 
Oxx = Not active (reset value). 
100 = Equal to. 
101 = Less than. 
110 = Greater than. 
111 = Not equal to. 


CRWE—Select Match on Read/Write of Comparator E 


Ox = “Don’t care” (reset value). 
10 = Match on read. 
11 = Match on write. 


CRWF—Select Match on Read/Write of Comparator F 


Ox = “Don’t care” (reset value). 
10 = Match on read. | 
11 = Match on write. 


CSG—Compare Size, Comparator G 


00 = Reserved. 
01 = Word. 
10 = Half-word. 
11 = Byte. 


CSH—Compare Size, Comparator H 
00 = Reserved. 
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01 = Word. 
10 = Half-word. 
11 = Byte. 
SUSG—Signed/Unsigned Operating Mode for Comparator G 
O= Signed. | | 
1 = Unsigned. 
SUSH—Signed/Unsigned Operating Mode for Comparator H 
O= Signed. 
1 = Unsigned. 


CGBMSK—Byte Mask for Comparator G 


0000 = All bytes are not masked. 
0001 = Last byte of the word is masked. 


1111  =All bytes are masked. 
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CHBMSK—Byte Mask for Comparator H | | : 


0000 = All bytes are not masked. 
0001 = Last byte of the word is masked. 


1111 = All bytes are masked. 


Bits 30-3 1—Reserved | | 
These bits are reserved and should be set to 0. 


20.6.2.7 LOAD/STORE SUPPORT AND-OR CONTROL REGISTER. The load/store 
. support AND-OR control (LCTRL2) register is used to control the bit masks for load/store 
data comparisons. Watchpoint programming consists of three control register fields— 
LWxIA, LWxLA, and LWxLD. All three conditions must be detected to assert a watchpoint. 
The reset value of this register is OxOOOO0000. 


LCTRL2 


a - 
2g 
> 
ow 
i 
— 
. TT 
RO: 
mae 
=. 
a | 
a 
“Th 
p> 
.?) 





oe 


LWiL | BRKN DLWO | DLW1 | SLWO | SLW1 
ow [ew [awfew] wf | | 


157 





LWOEN—First Load/Store Watchpoint Enable 


0 = Watchpoint not enabled (reset value). 
1 = Watchpoint enabled. 


LWOIA—First Load/Store Watchpoint |-Address Watchpoint Selection 
00 = First instruction watchpoint. 


01 = Second instruction watchpoint. 
10 = Third instruction watchpoint. 
11 = Fourth instruction watchpoint. 
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LWOIADC—First Load/Store Watchpoint Care/Don’t Care I-Address Events 


0= “Don't care.” 
1 = “Care.” 


LWOLA—First Load/Store Watchpoint L-Address Events Selection 


00 = Match from comparator E. 

01 = Match from comparator F. 

10 = Match from comparators E & F. 
11 = Match from comparators E | F. 


LWOLADC—First Load/Store Watchpoint Care/Don’t Care L-Address Events 
O= “Don't care.” 
1= “Care.” 


LWOLD—First Load/Store Watchpoint L-Data Events Selection 


00 = Match from comparator G. 

01 = Match from comparator H. 

10 = Match from comparators G & H. 
11 = Match from comparators G | H. 


LWOLDDC—First Load/Store Watchpoint Care/Don’t Care L-Data Events 


0= “Don’t care.” 
1= “Care.” 


LW1EN—Second Load/Store Watchpoint Enable 


0 = Watchpoint not enabled (reset value). 
1 = Watchpoint enabled. 


LW11A—Second Load/Store Watchpoint I-Address weenie Selection 


00 = First instruction watchpoint. 

01 = Second instruction watchpoint. 
10 = Third instruction watchpoint. 
11 = Fourth instruction watchpoint. 


LW1!1ADC—Second Load/Store Watchpoint Care/Don’t Care |-Address Event 


0= “Don’t care.” 
1= “Care.” 


LW1LA—Second Load/Store Watchpoint L-Address Events Selection 


00 = Match from comparator E. 
01 = Match from comparator F. 
10 = Match from comparators E & F. 
11 = Match from comparators E | F. 


LW1LADC—Second Load/Store Watchpoint Care/Don’t Care L-Address Events 


O= “Don't care.” 
1= “Care.” 
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LW1LD—Second Load/Store Watchpoint L-Data Events Selection 


00 = Match from comparator G. 

01 = Match from comparator H. 

10 = Match from comparators G & H. 
11 = Match from comparator G | H. 


LW1LDDC—Second Load/Store Watchpoint Care/Don’t Care L-Data Events 


: = “Don’t care.” 
— “Care. 33 


BRKNOMSK—Internal Breakpoints Nonmask Bit Controls Both Instruction Breakpoints and 
Load/Store Breakpoints 


O= Masked mode, breakpoints are recognized only when MSRa, =1 (reset value). 
1 = Nonmasked mode, breakpoints are always recognized. 


Bits 21—-27—Reserved 
These bits are reserved and should be set to 0. 


DLWOEN—Development Port Trap Enable Selection of the First Load/Store Watchpoint 
(Read-Only Bit) 

O= Trap disabled (reset value). 

1 = Trap enabled. 


DLW1EN—Development Port Trap Enable Selection of the Second Load/Store salenpaln 
(Read-Only Bit) | | 


0= Trap disabled (reset value). 
1 = Trap enabled. 


SLWOEN—Software Trap Enable Selection of the First Load/Store ee ee 


0 = Trap disabled (reset value). 
1= Trap enabled. 


SLW1EN—Software Trap Enable Selection of the Second Load/Store Watchpoint 


O= Trap disabled (reset vale) 
1 = Trap enabled. 
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20.6.2.8 BREAKPOINT COUNTER A VALUE AND CONTROL REGISTER. The 
breakpoint counter A value and control (COUNTA) register is used to count watchpoint 
events and to generate breakpoints a programmable amount of time after a watchpoint 
Occurs. 


COUNTA 
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NOTE: — = Undefined. 





CNTV—Counter Preset Value 


This field contains the number of watchpoint events to be encountered before a breakpoint 
is generated. 


Bits 16-—29—Reserved 
These bits are reserved and should be set to 0. 


CNTC—Counter Source Select 


00 = Not active (reset value). 

01 = Instruction first watchpoint. 
10 = Load/store first watchpoint. 
11 = Reserved. 
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20.6.2.9 BREAKPOINT COUNTER B VALUE AND CONTROL REGISTER. The 
breakpoint counter B value and control (COUNTB) register is used to count watchpoint 
events and to generate breakpoints a programmable amount of time after a watchpoint 
occurs. 


COUNTB 





a i] 2 E 


pecteeeeetter Srerreoeeter te 
a 


NOTE: — = Undefined. 


0z | 


0 
mi. 
=< 
m 
i- 
O 
a) 
mm. 
a 
rea 





a?) 
2 
Pod 
ay 
a 
DM 
fro 
z 
nf 
m. 
& 
<4 
© 


CNTV—Counter Preset Value 


This field contains the number of watchpoint events to be sacounisied before a breakpoint 
is generated. 


Bits 16-29—Reserved 
These bits are reserved and should be set to O. 


CNTC—Counter Source Select 


00 = Not active (reset value). 

01 = Instruction second watchpoint. 
10 = Load/store second watchpoint. 
11 = Reserved. 
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20.6.3 Debug Mode Registers 


20.6.3.1 INTERRUPT CAUSE REGISTER. The interrupt cause register (ICR) provides the 
reason for entering debug mode. All bits are set by the hardware, cleared when the register 
is read, and cleared to zero when exiting reset. Any attempt to write to this register is 
ignored. The reset value for this register is OxOOOO0000. 


ICR 


CAPABILITIES & INTERFACE 
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Bits 0, 4, and 5—Reserved 
These bits are reserved and should be set to 0. 





RST—Reset Interrupt 
This bit is set when the system reset pin is asserted. This pin is not mpleenied! in the core. 


CHSTP—Check Stop 


This bit is set when the machine check interrupt is asserted and MSRy- =0. The core enters 
debug mode if enabled and the CHSTP bit in the DER is set. Otherwise, the processor 
_ enters the check stop state. 


MCI—Machine Check Interrupt 


This bit is set when the machine check interrupt is asserted and MSRy_ =1. The core enters 
debug mode if enabled and the MCI bit in the DER is set. 


EXTI—External Interrupt 


This bit is set when the external interrupt is asserted. The core enters debug mode if enabled 
and the EXTI bit in the DIR is set. 


ALI—Alignment Interrupt 


This bit is set when the alignment interrupt is asserted. The core enters debug mode if 
enabled and the ALI bit in the DIR is set. 
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PRI—Program Interrupt 


This bit is set when the program interrupt is asserted. The core enters in débiig mode if 


enabled and the PRI bit i in the DER is set. 


FPUVI—Floating- -Point Unavailable Interrupt 


This bit is set when the floating-point unavailable interrupt is asserted. The core enters 
debug mode if enabled and the FPUVI bit in the DER is set. 


DECI—Decrementer Interrupt 


— This bit is set when the decrementer interrupt is ; asserted. The core enters debug mode if 


enabled and the DECI bit in the DER is set. 


Bits 11-12, 15-16—Reserved 
These bits are reserved and should ae set to 0. 


| SYSI_System Call Interrupt 


This bit is set when the system call interrupt is sesetied, The core enters cents mode if 
enabled and the SYS! bit | in the DER is set. | . 


TR—Trace Interrupt 


This bit is set when in single- step mode or when in branch trace mode. The core enters | 
debug mode if enabled and the TR bit in the DER is set. 


SEI—Implementation Dependent Software Emulation Interrupt 


This bit is set when the floating-point assist interrupt is asserted. The core enters debug 
mode if enabled and the SEI bit in the DER is set. 


ITLBMS—Implementation Specific Instruction TLB Miss | 


This bit is set as a result of an instruction TLB miss.The core enters ick mode if eiabice 
and the ITLBMS bit in the DER Is set. 


DTLBMS—Implementation Specific Data TLB Miss 


This bit is set as a result of an data TLB miss. The core enters debug mode if enabled and 
the DTLBMS bit in the DER is set. 


ITLBER—Implementation Specific Instruction TLB Err 


This bit is set as a result of an instruction TLB error. The core enters debug mode if enabled 
and the ITLBER bit in the DER is set. 


~ DTLBER—Implementation Specific Data TLB Error 


This bit is set as a result of an data TLB error. The core enters sebiet mode if enabled and 
the DTLBER bit in the DER is set. 


Bits 22—27—Reserved 
These bits are reserved and should be set to 0. 
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LBRK—Load/Store Breakpoint Interrupt 


This bit is set as a result of the assertion of an load/store breakpoint. The core enters debug 


mode if enabled and the LBRK bit in the DER is set. 


IBRK—Instruction Breakpoint Interrupt 


This bit is set as a result of the assertion of an instruction breakpoint. The core enters debug 


mode if enabled and the IBRK bit in the DER is set. 


EBRK—External Breakpoint Interrupt 


This bit is set as a result of the assertion of an external breakpoint. The core enters debug 


mode if enabled and the EBRK bit in the DER is set. 


DPI—Development Port Interrupt 


This bit is set by the development port as a result of a debug station nonmaskable request 


or when entering debug mode immediately out of reset. The core enters debug mode 
enabled and the DPI bit in the DER is set. 


20.6.3.2 DEBUG ENABLE REGISTER. The debug enable register (DER) allows the 
enabling of events that cause the processor to enter debug mode. 


DER 


ee MCIE RESERVED | EXTIE | ALIE | ee DECIE| RESERVED | SYSIE 
ps fo peo fofofofo] o jofr. 
aw | aw | orw | aw | aw | aw | nn | 


ne ITLBERE ve RESERVED LBRKE 
49 
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Bits 0, 4, and 5—Reserved 
These bits are reserved and should be set to 0. 


RS TE—Reset Interrupt Enable 


0 = Debug mode entry is disabled (reset value). 
1 = Debug mode entry is enabled. 
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CHSTPE—Check Stop Enable 


0 = Debug mode entry is disabled. 
1 = Debug mode entry is enabled (reset value). 


MCIE—Machine Check Interrupt Enable 


-~ 0= Debug mode entry is disabled (reset value). 
1 = Debug mode entry is enabled. 


EXTIE—External Interrupt Enable 


0. = Debug mode entry is disabled (reset valle): 
1 = Debug mode entry is enabled. 


ALIE—Alignment Interrupt Enable 


O = Debug mode entry is disabled (reset value). 
1 = Debug mode entry is enabled. 7 


PRIE—Program Interrupt Enable 


0 = Debug mode entry is disabled (reset value). 
1 = Debug mode entry is enabled. 


FPUVIE—Floating-Point Unavailable Interrupt Enable 


0 = Debug mode entry is disabled (reset value). 
1 = Debug mode entry is enabled. 


DECIE—Decrementer Interrupt Enable 


0 = Debug mode entry is disabled (reset value). 
- 1 = Debug mode entry is enabled. 


Bits 11-12 and 15-16—Reserved 
These bits are reserved and should be set to 0. 


SYSIE—System Call Interrupt Enable 


0 = Debug mode entry is disabled (reset value). 
1 = Debug mode entry is enabled. 


TRE—Trace Interrupt Enable 


0 = Debug mode entry is disabled. 
1 = Debug mode entry is enabled (reset value). 


SEIE—Software Emulation Interrupt Enable 


0 = Debug mode entry is disabled (reset value). 
1 = Debug mode entry is enabled. 


ITLBMSE—Implementation Specific Instruction TLB Miss Enable 


0 = Debug mode entry is disabled (reset value). 
1 = Debug mode entry is enabled. 
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ITLBERE—Implementation Specific Instruction TLB Error Enable 


0 = Debug mode entry is disabled (reset value). 
1 = Debug mode entry is enabled. 


DTLBMSE—Implementation Specific Data TLB Miss Enable 


0 = Debug mode entry is disabled (reset value). 
1 = Debug mode entry is enabled. 


DTLBERE—Implementation Specific Data TLB Error Enable 


O = Debug mode entry is disabled (reset value). 
1 = Debug mode entry is enabled. 


Bits 22-27—Reserved 
These bits are reserved and should be set to 0. 


LBRKE—Load/Store Breakpoint Interrupt Enable 


0 = Debug mode eniry is disabled. 
1 = Debug mode eniry is enabled (reset value). 
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| IBRKE—Instruction Breakpoint Interrupt Enable 


0 = Debug mode eniry is disabled. 
1 = Debug mode entry is enabled (reset value). 





EBRKE—External Breakpoint Interrupt Enable | 


0 = Debug mode entry is disabled. 
1 = Debug mode entry is enabled (reset value). 


DPiE—Development Port Nonmaskable Request Enable 


0 = Debug mode entry is disabled. 
1 = Debug mode entry is enabled (reset value). 
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20.6.4 Development Port Data Register — a . fg, #8 


The special-purpose development port data register (DPDR) physically resides in the 
development port logic. It is used for data interchange between the core and development 
system. An access to this register is initiated using the mtspr and mfspr instructions and it 
is implemented using a special bus cycle on the internal bus. For details, see Table 6-9. 





DPDV—Development Port Data Value : | | 


This field contains the data to be transferred between the core and the development system. 


DPIR i> # oe ee ee 





NOTE: — = Undefined. 


DPIV—Development Port Instruction Value 
This field is used to fetch an instruction supplied by the development system. 
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SECTION 21 
IEEE 1149.1 TEST ACCESS PORT 


The MPC823 provides a dedicated user-accessible test access port (TAP) that is fully 
compatible with the /EEE 1149.1 Standard Test Access Port and Boundary Scan 
Architecture. Problems associated with testing high-density circuit boards have led tothe 
development of this proposed standard under the sponsorship of the Test Technology 
Committee of IEEE and the Joint Test Action Group (JTAG). The MPC823 plementation 
supports circuit board test strategies based on this standard. 


The TAP consists of five dedicated signal pins, a 16-state TAP controller, and two test data 
registers. A boundary scan register links all the device signal pins into a single shift register. 
The test logic, which is implemented using static logic design, is independent of the device 
system logic. The MPC823 implementation provides the capability to: 


e Perform boundary scan operations to check circuit board electrical continuity. 


e Bypass the MPC823 for a given circuit board test by effectively reducing the boundary 
scan register to a single cell. 


Sample the MPC823 system pins during operation and transparently shift out the result 
in the boundary scan register. 


Disable the output drive to pins during circuit board testing. 





Note: Certain precautions must be observed to ensure that the IEEE 1149.1-like test 
logic does not interfere with nontest operation. 
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IEEE 1149.1 Test Access Port 


The MPC823 implementation includes a TAP controller, a 4-bit instruction register, and two 
test registers (a 1-bit bypass register and a 397-bit boundary scan register). An overview of 
the MPC823 scan chain implementation is illustrated in the figure below. The TAP controller 
consists of the following signals: 


e TCK—A test clock input to synchronize the test logic. 


¢ TMS—A test mode select input (with an internal pull-up resistor) that is sampled on the 
rising edge of TCK to sequence the TAP controller's state machine. 


¢ TDI—A test data input (with an internal pull-up resistor) that i Is sampled on the rising 
edge of TCK. 


¢ TDO—A three-stateable test data output that is actively driven in the shift-IR and 
shift-DR controller states. TDO changes on the falling edge of TCK. 


e TRST—An asynchronous reset with an internal pull-up resistor that provides TAP 
controller initialization and other logic required by the standard. For normal operation of 
the MPC823, this signal pin must make a level transition to low before initialization 
begins. Typically, if the TAP is used, connect the TRST elgnaie to PORESET, HRESET, 

_ Or SRESET. 
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Figure 21-1. Test Logic Block Diagram 
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21.1 THE TAP CONTROLLER 


The TAP controller is responsible for interpreting the sequence of logical values on the TMS 
signal. It is a synchronous state machine that controls the operation of the JTAG logic. The 
value shown adjacent to each bubble in the figure below represents the value of the TMS 
signal sampled on the rising edge of the TCK signal. 


TEST LOGIC 
RESET 
1 
0 
1 1 1 
RUN—TEST/IDLE SELECT—DR_SCAN ~y( SELECT—IR_SCAN 
@) 


CAPTURE—DR CAPTURE—IR 
0 


SHIFT—DR 


EXIT1—DR EXIT1—IR 


PAUSE—DR PAUSE—IR 


EXIT2—DR EXIT2—IR 
UPDATE—DR UPDATE—IR 


fo — 


Figure 21-2. TAP Controller State Machine 
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21.2 THE BOUNDARY SCAN REGISTER 


The MPC823 scan chain implementation has a 397-bit boundary scan register that contains 
bits for all device signal, clock pins, and the associated control signals. However, the XTAL, 
EXTAL, and XFC pins are associated with analog signals and are not included in the. 
boundary scan register. An IEEE-1149.1-compliant boundary scan-register has been 
included on the MPC823. This 397-bit boundary scan register can be connected between 
the TDI and TDO signals when the extest or sample/preload instructions are selected. It is 
used for capturing signal pin data on the input pins, forcing fixed values on the output signal 
pins, and selecting the direction and drive characteristics (a logic value or high impedance) 
of the bidirectional and three-state signal pins. Figure 21-3 through Figure 21-6 depict the 
various Cell types. 


{ — EXTEST | CLAMP SHIFTDR TO NEXT CELL 
0 — OTHERWISE 


DATA FROM 


SYSTEM 7 TO OUTPUT 
LOGIC | BUFFER 


: 


FROM LAST CELL ~—— CLOCKDR ~—_—sUPDATEDR 
Figure 21-3. Output Pin Cell (O.Pin) 
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TO NEXT CELL 


DATA TO 
SYSTEM 
LOGIC 





Figure 21-4. Observe-Only Input Pin Cell (1.Obs) 
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FROM LAST CELL CLOCK DR UPDATE DR 


Figure 21-5. Output Control Cell (1O.CTL) 
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FROM LAST CELL 


OUTPUT ENABLE 
FROM SYSTEM. VO.CTL 
LOGIC 


OUTPUT DATA 


INPUT DATA 


TO NEXT PIN PAIR 
TO NEXT CELL : 





Figure 21-6. General Arrangement of Bidirectional Pin Cells 


The value of the control bit controls the output function of the bidirectional pin. One or more 
bidirectional data cells can be serially connected to a control cell. Bidirectional pins include 
two scan cell for data (lO.Cell) as illustrated in Figure 21-6 and these bits are controlled by 
the cell illustrated in Figure 21-5. | 


It is important to know the boundary scan bit order and the pins that are associated with 
them. The bit order starting with the TDO output and ending with the TDI input is shown in 
Table 21-1. The first column of the table defines the bit’s ordinal position in the boundary 
scan register. The shift register cell nearest TDO (first to be shifted in) is defined as Bit O and 
the last bit to be shifted in is Bit 396. The second column references one of the three 
MPC823 cell types depicted in Figure 21-3 through Figure 21-6 that describe the cell 
structure for each type. The third column lists the pin name for all pin-related cells and 
defines the name of the bidirectional control register bits. The fourth column lists the pin type 
and the last column indicates the associated boundary scan register control bit for the 
bidirectional output pins. | 
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Table 21-1. Boundary Scan Bit Definition 


BIT CELL TYPE PIN/CELL NAME PIN TYPE OUTPUT 
CTL CELL 
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Table 21-1. Boundary Scan Bit Definition (Continued) 


BIT | CELL TYPE PIN/CELL NAME PINTYPE | OUTPUT 
| | CTL CELL 
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Table 21-1. Boundary Scan Bit Definition (Continued) 


BIT CELL TYPE PIN/CELL NAME PIN TYPE OUTPUT 
CTL CELL 
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Table 21-1. Boundary Scan Bit Definition (Continued) 


BIT CELL TYPE PIN/CELL NAME PIN TYPE OUTPUT 
CTL CELL 


03. 


103. lO.ctl G204.CTL 


WE3_B_BSAB3_B_PCWEB 

















104 
105. 
106 


WE1_B_BSAB1_B_IOWR_B 
WE2_B_BSAB2_B_PCOE_B 
WEO0_B_BSABO_B_IORD_B 





107 


—_ 


08 
09 


GPLAO_B._GPLBO_B 
OE_B_GPLAB1_B 
-o.pin GPLAB2_B_CS2_B 


— 


0 


— 
—_ 
—h 


—, 
—_ 


=. 
— 
on 


Pm [oe [eon Sid YO 
Vm [ioe [cree upware | o | 
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ver | iwe [or eupwara | | — 
es [one | crmeupwara [0 | ea 
[fa [oe [sn 
130 


BDIP_B_GPLB5_B 
BI_B 
BI_B 


—_h 
—k 


2 
113 
114 


are ee oe Pe ea ee 
er ee ee eee a ee 
oO; CO; no 


© 


: ees 


LYOd SS399V 
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oh 
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oar 
— 
m 
” 
—| 





21-10 MPC823 USER’S MANUAL MOTOROLA 


IEEE 1149.1 Test Access Port 


Table 21-1. Boundary Scan Bit Definition (Continued) 


BIT CELL TYPE PIN/CELL NAME PIN TYPE OUTPUT 
CTL CELL 


137 


TEA_B 
TEA_B 
G89.CTL 
TS_B 
TS_B 
G97.CTL 
BR_B 
BR_B 
G21.CTL 







— 
hb 
fan) 






— 
ao 
Co 


g89.ctl 





139 lO.ctl 


—k. 
> 
— 


g97.ctl 
142 10.ctl 






—_ 
r 
(oe) 


i.obs 


= 
r 
rm 


g21.ctl 
145 lO.ctl 









—k 
(op) 
= 


IPB4_LWP0_VFO 

. IPB4_LWPO_VFO 
G150.CTL 

IPB3_IWP2_VF2 

IPB3_IWP2_VF2 


; g150.ctl 


— 
o> 
on 


166 1O.ctl 
167 


g Cc 


— 
ol 
— 
— 


BRB 
ae a ee 
a 
a 
163 | ‘IO G15.CTL a 
p10 | 

ee 

bfeead 

p10 

0 | 
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Table 21-1. Boundary Scan Bit Definition (Continued) 


|} BIT. CELL TYPE PIN/CELL NAME PIN TYPE OUTPUT 
| CTL CELL 


Te [ea [ewer sd 

cs 

[ious | reowroveisy [0 [| — 

Tm [enn | Peo.wro.viso | 0 | sisoat 
174 
















| tm | IPB7_PTR_AT3 Ee 
175 IPB7_PTR_AT3 
lO.ct G13.CTL | P| 
IPB2_IOIS16B_B_AT2 po 
IPB2_IOIS16B_B_AT2 
179 lO.ctl G41.CTL po 
180 ALEB_DSCK_AT4 po 
181 ALEB_DSCK_AT1 


182 lO.cth G16.CTL 
IPB6_DSDI_ATO 
IPB6_DSDI_ATO 

G14.CTL 
KR_B_IRQ4_B_SPKROUT 
KR_B_IRQ4_B_SPKROUT 

G95.CTL 

OP2_MODCK1_STS_B | 
OP2_MODCK1_STS_B 

G92.CTL | 

OP3_MODCK2_DSDO 

OP3_MODCK2_DSDO 
G91.CTL 
CLK4IN 
TEXP 
HRESET_B 
HRESET_B 

— @94.CTL 
SRESET.B 
SRESET_B 
G93.CTL 


g14.ctl 
g95.ctl 


| © 


— 
© 
o> 


185 10.ctl 


— 
[oe] 
a | 


188 | Oct 


— | — 
co CO 
(om) ie} 


g92.ctl 
g91.ctl 


191 lO.ctl 
192 


3m 
On 
om 

Oa. 
MO 
vO. 
“Om 
oie 

= 

my 
— 


— 
CO 
(ee) 





ale 


94 O.ctl 
195 i.obs - 

196 
197 
198 


199 10.cth 


g94.ctl 








g93.ctl 


B ‘ 
1 & 
_ © 


20 





202 — lO.ctl 
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Table 21-1. Boundary Scan Bit Definition (Continued) 


BIT CELL TYPE PIN/CELL NAME PIN TYPE OUTPUT 
CTL CELL 


os 
[ete | ponesers [4 
205 obs WAITB_B pS 
CLKOUT P| 
DPO_IRQ3_B 
DPO_IRQ3_B 
DP3_IRQ6_B 
DP3_IRQ6_B 
G18.CTL 
DP2_IRQ5_B 
DP2_IRQ5_B 
DP1_IRQ4_B 
DP1_IRQ4_B 
Di34] 
DI34] 
G103.CTL 
Di30] 
Di30] 
DI29] 
DI29] 
DI7] 
D[7] 
D[28] 
D[28] 
D[26] 
DI26] 
DI25] 
D[25] 
D(24] 
Di24] 
Di21] 
Di21] 
G102.CTL 
Di22] 
























2 


oOo 


6 o.pin 


DN 
(on) 
ale 


ibe) 
[>] 
Cc 


O.pin 








NO 
(on) 
ice) 


i.obs 
210 
211 10.ctl 


ine) 
—_ 
PO 


o.pin 


1 


g18.ctl 
g103.ctl 
g103.ctl 


g103.ctl 


g108.ctl 


g103.ctl 


g103.ctl 


g103.ctl 


g103.ctl 
g102.ctl 


—_—, 


ro no 
—_— 
BEE 


no 
NO 
(on) 


215 o.pin | 
216 

217 o.pin 
218 1O.ctl 


219 i.obs 


nm | bo 
nm | PR 
pf} — 


No 
rh | bo 
(ee) 


NO 
aS 


o.pin 
225 

226 © 

227 i.obs 





Hoke 
Ea. 
nO. 
oo 
t+y) 

ee) 
we 


rh |} 
ND | PO 
Cc {| € 


230 
23 


—_— 


ine) 
oO 


ine) 
oO 
(Fe) 


234 o.pin 
lO.ctl 
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_ Table 21-1. Boundary Scan Bit Definition (Continued) 


BIT CELL TYPE PIN/CELL NAME PIN TYPE. OUTPUT 
| CTL CELL 


a 










[es D119 a 
[ie DIt5} ee aed 
oa D116) <a 
[eon 
se O15} mia 
G101.CTL 


g101.ctl 
g101.ctl 
g101.ctl 


g101.ctl 
g101.cti 
g101.ctl 


g101.ctl 


g100.ctl 


DI3] 
D[3] 
D[14] 
D[14] 
D[2] 
D[2] 
D[11] 
D[11] 










; 
on. 
Om 
i 
. _ 4 
Op 
ag 
om. 
aa 
Nn 
| 





D[10] 


D[17] 
D[17] 
D[27] 
D[27] 
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Table 21-1. Boundary Scan Bit Definition (Continued) 


BIT CELL TYPE PIN/CELL NAME PIN TYPE OUTPUT 
CTL CELL 


Fs 
Fs 
Pa [eam [om S*d— i 













| opin 
an 
278 | obs D[12] Ded 


G10.CTL 
PD[3] 
PD[3] 

G9.CTL 
PD[5] 
PD[5] 

G8.CTL 


289 1O.ctl 


Nm | PM 
co |} © 
= | © 


92 1O.ctl 


293 
294 


a 

Lu ke 
ra 
oo 
rm 
= @ 
ers) 
Lu ¢) 
Wu ef 


295 lO.ctl 


i.obs 





NO 
co 
Ni 


298 1O.ctl 
299 i.obs 


G7.CTL 
PD[4] 
PD{4] 

G6.CTL 
PD{7] 
PD{7] 

G5.CTL 


(ee) 
(=) 
(on) 


N 
CO 
o> 


301 lO.ctl 


[ce] 
© 
ine) 


303 
1O.ctl 
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Table 21-1. Boundary Scan Bit Definition (Continued) 


CELL TYPE PIN/CELL NAME PIN TYPE OUTPUT 
CTL CELL 


a 
ee 
Cer [wa [wom —~i| - | — 

ee 


g3.ctl 










w 
oS 
ico) 


310 
3 
312 

313. lO.ctl 


lO.ct G3.CTL 
PD[10] 
PD[10] 
G2.CTL 
PD[11] 
PD[11] 
G1.CTL 
PD[12] 
PD[12] 
G81.CTL 
PD[13] 
PD[13] 
G80.CTL 
PD[14] 
PD[14] 
G79.CTL 
PD[15] 
PD[15] 
G78.CTL 
PC[4] 
PC[4] 
G26.CTL 
PC[5] 
PC[5] 
G27.CTL 
PB[16] 
PB[16] 
G40.CTL 
PC[6] 


(ee) 
NO 
& 


g2.ctl 
g1.ctl 


g81.ctl 


—_—, 
—_— 


ow }] @ 
—_— | ak 
on; & 


316 lO.ctl 
317 
318 
319 1O.ctl 


oo 
NO 
© 


g80.ctl 


oo 
NO 
—h, 


322 1O.ctl 


(ee) 
nN 
(ee) 


g79.ctl 
g78.ctl 
g26.ctl 


g27.ctl 


g40.ctl 


325 lO.ctl 
326 
327 
328 lO.ctl 


- | > im 
Om. 
Om 

. Oo 
—_, 

O = 
uo 
o- 
Am 

w” 

o=nf 


(oe) 
N 
co 





(Se) 
G 
fon) 


331 lO.ctl 
332 
333 

34 





lO.ctl 


(Fe) 
(se) 
on 


oa 
(de) 
(o>) 


337: 1O.ctl 
338 
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Table 21-1. Boundary Scan Bit Definition (Continued) 


BIT CELL TYPE PIN/CELL NAME PIN TYPE OUTPUT 
CTL CELL 


ee; 
ee a ee ae ae 
2 a we 
pe | onin | P| 
Le eat ee 
[oa [tae [ert 
eee ee 
a a 
ee ae 
) a | onin | PAM 
ee eee 
a 
ce ae ee. ae 
| 32 | oat | ec 
ee eee ee 
zs 
| 5 
Es 
3st | 
38 
Es 
| 300 
3st 
zz 
Eo 
4 
[965 































g66.ctl 


re a 
ee 
es 
ae 
ee 

oe 

ae 


g67.ctl 
g49.ctl 


Lu ee. 
ea 
9 

o O- 

Tw 

= i 

Lig). . 

ae) 

a 





[ce] 
[o>] 
on 


g69.ctl 


371 
372 


g70.ctl 
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Table 21-1. Boundary Scan Bit Definition (Continued) 


BIT CELL TYPE PIN/CELL NAME PIN TYPE OUTPUT 
CTL CELL 


Tm [ea | ee =i - ‘| - 
Taw [tone [roa Sif 
Vas [enn | rewa—i| |e 
pa [Tes [een 
“Ss 














[ee] 
~J 
co 


g53.ctl 


oo 


oa 
fe} 
(ee) 


g55.ctl 





Gd 
co 
on 


1O.ctl 


io} 
GQ) 
Hf 
r?) 
panes 
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21.3 THE INSTRUCTION REGISTER 


The MPC823 JTAG implementation includes the public instructions—extest, sample/ 
preload, bypass, and clamp. One additional public instruction—hi-z—is capable of 
disabling all device output drivers. The MPC823 includes a 4-bit instruction register that 
consists of a shift register with four parallel outputs. Data is transferred from the shift register 
to the parallel outputs during the update-IR controller state. The four bits are used to decode 
the five unique instructions listed in Table 21-2. 


Table 21-2. Instruction Decoding 


CODE INSTRUCTION 


eS ee a ee EXTEST 


SAMPLE/PRELOAD 


cr a 


CLAMP and BYPASS 





The parallel output of the instruction register is reset to all ones in the test-logic-reset 
controller state. Notice that this preset state is equivalent to the bypass Instruction. During 
the capture-IR controller state, the parallel inputs to the instruction shift register are loaded 
with the clamp command code. 


21.3.1 The External Test Instruction 


The external test (extest) instruction selects the 397-bit boundary scan register and asserts 
an internal reset for the MPC823 system logic to force a Known beginning internal state while 
performing external boundary scan operations. By using the TAP controller, the register is 
capable of scanning user-defined values into the output buffers, capturing values presented 
to the input pins, and controlling the output drive of three-stateable output or bidirectional 

pins. For more details on the function and use of extest, refer to the IEEE 1149.1 standard. 


- 

a4 

i th Oe 
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21.3.2 The sample/preload Instruction 


The sample/preload instruction initializes the boundary scan register output cells before 
extest is selected. This initialization ensures that known data will appear on the outputs 
when entering the extest instruction. The sample/preload instruction also provides an 
opportunity to obtain a snapshot of system data and control signals. 


Es Note: Since there is no internal synchronization between the TCK and CLKOUT, you 
| y, must provide some form of. external synchronization between the JTAG 
operation TCK frequency and system operation CLKOUT frequency to achieve 

meaningful results. 


21.3.3 The bypass Instruction 


The bypass instruction creates a shift register path from TDI to the bypass register and, 
finally, to the TDO pins, thus circumventing the 397-bit boundary scan register. This 
instruction is used to enhance test efficiency when a component other than the MPC823 is 
the device being tested. It selects the single-bit bypass register as illustrated in Figure 21-7. 


SHIFT DR 


0 


FROM TDI 


CLOCK DR 





Figure 21-7. Bypass Register 


When the bypass register is selected by the current instruction, the shift register stage is set 


to a logic zero on the rising edge of the TCK pin in the capture-DR controller state. _ 
Therefore, the first bit to be shifted out after selecting the bypass register is always a logic 
zero. | 


21.3.4 The clamp Instruction 


The clamp instruction selects the single-bit bypass register as illustrated in Figure 21-7 
above, and the state of all signals driven from the system output pins is completely defined 
by the data previously shifted into the boundary scan register. 


21.3.5 The hi-z Instruction 


The hi-z instruction is provided as a manufacturer's optional public instruction/On to avoid 
back driving the output pins during circuit board testing. When hi-z is invoked all output 
drivers, including the two-state drivers, are turned off (high impedance). The instructlon 
selects the bypass register. 


21-20 -MPC823 USER’S MANUAL | MOTOROLA 


IEEE 1149.1 Test Access Port 


21.4 MPC823 RESTRICTIONS 


The control afforded by the output enable signals using the boundary scan register and the 
extest instruction requires a compatible circuit board test environment to avoid 
device-destructive configurations. You must avoid situations in which the MPC823 output 
drivers are enabled into actively driven networks. The MPC823 features a low-power stop 
mode. The interaction of the scan chain interface with low-power stop mode is as follows: 


1. The TAP controller must be in the test-logic-reset state to either enter or remain in the 
low-power stop mode. Leaving the TAP controller in the test-logic-reset state negates 
its ability to achieve low power, but does not otherwise affect device functionality. 


2. The TCK input is not disabled in low-power stop mode. To consume minimal power, 
the TCK input should be externally connected to Voc or ground while in low-power or 
normal mode (nonscan chain). 


3. The TMS, TDI, and TRST pins include on-chip pull-up resistors. In low-power stop 
mode, the TMS and TDI pins should remain either unconnected or connected to Veco 
to achieve minimal power consumption. For proper reset of the scan chain test logic, 
the best approach is to pull active TRST at power-on reset. The easiest way to reset 
the scan chain logic is to connect TRST to HRESET, SRESET, or PORESET. In 
power-down mode, you must ensure that the xRESET line is low during power-down 
so that you can conserve power. If the TAP controller is not used, you should ground 
the TRST signal. If, for some reason, the HRESET signal that you connected to TRST 
is high during power-down, the KAPWR supply will propagate through the TRST pin 
to undesired internal circuits and will increase power consumption. 
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SECTION 22 
ELECTRICAL CHARACTERISTICS 


This section contains basic information about power considerations, thermal characteristics, 
layout practices, and DC timing specifications for the MPC823. 


~T Note: So that we may provide you with the most current information, specific electrical 

ee information can be accessed from our website at www.mot.com/mpc823. If you 
do not have web access, please contact your local Motorola sales office for a 
printed copy. 7 


22.1 MAXIMUM RATINGS (GND = OV) 


Input Voltage (JTAG and GPIO) 
Input Voltage (All other pins) 
Ta 


Operating Temperature 0 to 70° 
or 
-40° to 85° 


Storage Temperature Range -55 to +150 ; 


1. Functional operating conditions are given in Section 22.4 DC Electrical 
Characteristics (VCC = 3.0 - 3.6 V). Absolute maximum ratings are stress 
ratings only, and functional operation at the maxima is not guaranteed. 
Stress beyond those listed may affect device reliability or cause permanent 
damage to the device. 


2. CAUTION: The JTAG and GPIO input voltages cannot be more than 2.5 V 
greater than supply voltage, this restriction applies also on “power-on” as well 
as on normal operation. 























° 
















3. 5 Volt friendly inputs are inputs that tolerate 5 volts for JTAG and GPIO pins. 


If you are using Mask Revision Base #F98S (Revision 0), all pins except 
EXTAL and CLK4IN are 5V tolerant inputs. 


ae 
TE 
Cu. 
Sky. 
et 
Oe. 
OE 
HO. 
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Electrical Characteristics 


This device contains circuitry protecting against damage from high-static voltage or 
electrical fields. However, it is advised that precautions be taken to avoid application of any 
voltages higher than the maximum-rated voltages to this high-impedance circuit. Reliability 
of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (either 
GND or Ve). 


22.2 THERMAL CHARACTERISTICS. 










CHARACTERISTIC | SYMBOL |. VALUE UNIT 


22.3 POWER CONSIDERATIONS . 


The average chip-junction temperature, T,, in n°C can be obtained from 


T,= 7, +(P,eq,,) (1) 


where 
T, = Ambient Temperature, ooC 
Gj, = Package Thermal Resistance, Junction to Ambient, -C/W 
Py = Pint + Pic : 
Pine = LaacX Vain: Watts—Chip Internal Power 
are = Power Dissipation on Input and Output Pins—User Determined 


For most applications P,,, < 0.3 eP,,, and can be neglected. If P,, is neglected, an 
approximate relationship between P,, and T, is: os 


Py, = K I] (T,+27300C) (2) 
Solving equations (1) and (2) for K gives 
K= Py 9 (T, +273«C) + q,,°Pp (3) 
where K is a constant pertaining to the particular part. K can be determined from equation 


(3) by measuring PS (at equilibrium) for a known T,. Using this value of K; the values of P,, 
and T , can be obtained oo sowing equations (1) and (2) pearer for any value of T,. 
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22.3.1 Layout Practices 


Each Ve pin on the MPC823 should be provided with a low-impedance path to the board’s 
supply. Each.GND pin should be provided with a low-impedance path to ground. The power 
supply pins drive distinct groups of logic on chip. The Veg power supply should be bypassed 
to ground using at least four 0.1 uF bypass capacitors located as close as possible to the 
four sides of the package. The capacitor leads and associated printed circuit traces 
connecting to chip Ve, and GND should be kept to less than half an inch per capacitor lead. 
A four-layer board is recommended, employing two inner layers as Voc and GND planes. 


All output pins on the MPC823 have fast rise and fall times. Printed circuit (PC) trace 
interconnection length should be minimized in order to minimize undershoot and reflections 
caused by these fast output switching times. This recommendation particularly applies to the 
address and data busses. Maximum PC trace lengths of six inches are recommended. 
Capacitance calculations should consider all device loads as well as parasitic capacitances 
due to the PC traces. Attention to proper PCB layout and bypassing becomes especially 
critical in systems with higher capacitive loads because these loads create higher transient 
currents in the Voc and GND circuits. Pull up all unused inputs or signals that will be inputs 
during reset. Take special care to minimize the noise levels on the PLL supply pins. 
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Electrical Characteristics 


22.4 DC ELECTRICAL CHARACTERISTICS (Voc = 3.0 - 3.6 V) 


CHARACTERISTIC _ | SYMBOL | ae UNIT 
NOTE: Input pin voltage specifications are Voc = +4 V or 5.8 V, whichever is less. 


AC timings are based on a 50 pf load. 


If you are using Mask Revision Base #F 988, all pins except EXTAL and CLK4IN are 5V tolerant inputs. 













Hi-z (Off State) eakane Current, VIN 3.5V 


Output High Voltage, lou = —2.0 MA, VppH = 3-0V 
Except XTAL, XFC, and Open-Drain Pins 









Output Low Voltage 
lOL=2.0 mA ae 







lOL = 3.2 mAA SIZO/REG Haas eee St) D Pore; :3/IRQ|3: 6] 
RD/WR, BURS eVIROP IP 5310: Hy HAS HELIO IP_B2/ 
4/LWPO 





lOIS16._ B/AT2 Ay B3/IWP2/VE2, | FO, | B /LWP4/ 
VF1, IP_B6/DSDI/ATO, IP B7/PIRIATS, USBRXDIPA15 RXD2/_ 
PA13, SMRXD2/L1TXDA/PA9, SMTXD2/L1RXDA/PAB, IRQ4/KR/ 
SPKROUT, TIN1/L1 CLKATSRGOT/CLKT/PAT, TIN3/TOUT1/ 
CLK2/PA6, TIN2/L1TCLKA/BRGO2/CLK3/PAS5, TIN4/TOUT2/CLK4/ 
PA4, LCD A/SPISEL/PB31, SPICLK/PB30, SPIMOSI/PB29, 
BRGO3/SPIMISO/PB28, B BRGOVI2CSDA/PB2/, BAGO O/N2CSCL/ 
PB26, SMTXD1/PB25, SMRXD1/PB24, SMSYN SDACKI/PB23, 
SMSYN2/SDACK2/PB22, LCD_B/L1ST1/PB19, ListoAT 

PB18, LCD_C/L1ST3/PB17, LiST4/L1RQA/PB16, 1 STE BAEOT/ 
PC15, LiST6/RTS2/DREQ2/PC14, L1ST7/PC13, L1ST8/L1RQA/ 
PC12. USBAXPIEC USBRXN/TGATE1/PC10, GTS2/PC9, 


LITSYNCA/PC5, L1RSYNCA/PC4, LD8/VD7/PD15, LD7/VD6/ 
PDI. vSSNIDEP BIS YDSMDAPDID. LD4/VD3/PD11, LD3/VD2/ 
PD10, LD2/VD1/PD9, LD1/VD0/PD8, FRAME/VSYNC/PD5, 
LCD_AC/LOE/BLANK/PD6, LD0O/FIELD/PD7, LOAD/HSYNC/PD4, 
SHIFT/CLK/PD3 


ne eee Res 6 WEOBS ABOIIORD 5 WE BS AB ee 

WEJIBS AB2/PCOE. WE3/BS_ AB3/PC ABIGPL BO, OE/ 

GPL _AVGPL Bi GPL Al23/GPL_Bi2 rose UPWAI 
PL—A4/AS, UPWAITB/GPL. Bd, LA) APE FipscKALL. 


OP2/MODCK1/STS, UPS MODCKS/DSDO 
IOL = 7.0 mA USBOE/PA14, TXD2/PA12 


IOL = 8.9 mATS, TA, TEA, BI, BB, HRESET, SRESET 
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SECTION 23 
MECHANICAL DATA AND ORDERING INFORMATION 


23.1 ORDERING INFORMATION 


PACKAGE TYPE FREQUENCY (MHz) TEMPERATURE ORDER NUMBER 
256-Lead Plastic Ball Grid Array with 25 0°C to 70°C XPC823ZT25 
1.27mm Ball Pitch 50 0°C to 70°C XPC823ZT50 

25 -45°C to -85°C XPC823CZT25_ 
256-Lead Plastic Ball Grid Array with 25 0°C to 70°C XPC823ZC25 
1.00mm Ball Pitch oe 


0°C to 70°C XPC823ZC50 

XPC823CZC25 
Contact your local Motorola sales office for the latest information on speed grades and part 
numbers. | 












-45°C to -85°C 
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Mechanical Data and Ordering Information 


23.2 PIN ASSIGNMENTS—PBGA—TOP VIEW 
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Mechanical Data and Ordering Information 


23.3 PACKAGE DIMENSIONS 


The following figure is a23x23mm package, which has 1.27mm spacing between pads. The 
device designator for the MPC823 in this package is ZT. For more information on the printed 
circuit board layout of the plastic ball grid array (PBGA) package, including thermal via 
design and suggested pad layout, please refer to AN-1231/D, Plastic Ball Grid Array 
Application Note available from your local Motorola sales office. 
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Mechanical Data and Ordering Information 


The following figures are mechanical drawings for the PBGA GTPAC, which is a 17x17mm 
package that has 1mm spacing between pads. The device designator for the MPC823 in this 
package is ZC. | 
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SECTION 24 
TERMINOLOGY 


ACRONYMS, MNEMONICS, AND UNITS OF MEASURE 


Us—Microsecond 

APG—Access Protection Group 
ASID—Address Space ID 

BD—Buffer Descriptor 

BRG—Baud Rate Generator | ae | 
CClTT—International Telegraph and Telephone Consultative Committee 
C/I—Command/Indication 
CPM—Communication Processor Module 
CRC—Cyclic Redundancy Check 
DiSFC—Discarded Frame Counter 
EBI—External Bus Interface 

FCS—Frame Check Sequence 
FD—Function Descriptor 

G—Gigabyte 

GCl—General Circuit Interface 
GPCM—General-Purpose Chip-Select Machine 
HDLC—High-Level Data Link Control 
I*C—Inter-Integrated Circuit 
IDG—Interdialog Gap 

[DL—Interchip Digital Link 
IDMA—Independent Direct Memory Access 
IDN—Integrated Digital Network 
IFG—Interframe Gap 

IMMR—Internal Memory Map Register 
lrDA—Infra-red 

IRLAP—Infra-Red Link Access Protocol 
JTAG—Joint Test Action Group 
KAPWR—Keep-Alive Power 

K—Kilobyte 

Kbd—Kilobaud 

KBps—Kilobytes Per Second 
Kbps—kKilobits Per Second 
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Terminology 


kHz—Kilohertz 

LAP-B—Link Access Protocol-Balanced 
LAP-D—Link Access Protocol-D Channel 
LRU—Least Recently Used 
M—Megabyte 

MAC—Multiply Accumulate 

Mb—Megabit 

Mbps—Megabits Per Second 
MF—Multiplication Factor 
MHz—Megahertz 

MIPS—Millions of Instructions Per Second 
MMU—Memory Management Unit 
NMiI—Nonmaskable Interrupt 
NMSI—Nonmaskable Serial Interrupt 
NTSC—National Television Standards Committee 
OSCM—Main Crystal Oscillator | 
OSI—Open Systems Interconnection 
PAL—Phase Alternation Line 
PBGA—Plastic Ball Grid Array 
PCi—Peripheral Component Interconnect 
PCM—Pulse-Code Modulation 
PLL—Phase-Locked Loop 
POR—Power-On Reset 
PPP—Point-to-Point Protocol 
PWM—Pulse-Width Modulation 
RMS—Root Mean Squared 

RX—Receive or Reception 

SCC—Serial Communication Controller 
SDMA—Serial Direct Memory Access 
SDN—Software Defined Network 
SMC—Serial Management Controller 
SPl—Serial Peripheral Interface 
$S7—Signaling System Number 7 
TAP—Test Access Port 
TDM—Time-Division Multiplex 
TFT—Thin Film Transistor 
TLB—Translation Lookaside Buffer 
TSA—Time-Slot Assigner 

TX—Transmit or Transmission 
UART—Universal Asynchronous Receiver/Transmitter 
UPM—User-Programmable Machine 
USB—Universal Serial Bus 
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Terminology 


TERMINOLOGY 


atomic cycle 


If multiple bus transactions by a bus master occur in a sequence where the master 
retains ownership of the bus during the duration of the sequence, thus preventing other 
master(s) from transferring in the middle of the sequence, the sequence is considered 
atomic. 


autobaud 
The process of determining a serial data rate by timing the width of a single bit. 


big-endian 


Big-endian ordering assigns the lowest address to the highest order (leftmost) eight bits 
of the scalar. This called big-endian because the big end of the scalar, considered a 
binary number, comes first in memory. | 


breakpoint 
An event that forces the machine to branch into a breakpoint exception routine. 


burst 
A bus transfer that has more than one piece of data associated with it. 


burst length 


The number of data associated with a burst cycle. For example, a burst a of four 
has four data pieces (four beats) associated with it. 


copyback 


Updates to external memory are delayed until forced by the user program or a transfer 
of bus control to an external master. At the time of forced update or relinquishment of 
the bus, all changes to the cache are written to external memory. Until that time, cache 
and external memory are not coherent. 


critical-data first 


This feature allows the data transferred during the burst cycle to be organized where 
the word or data needed first is the first one to transfer within the burst-data block. The 
order of transferring can be sequential and usually wraps back to the word (or data) 
zero. For example, 1 2 — 3 > 0 for a sequence of four data with data 1 as the ee 
data. 7 


critical-word first 
The word that the processor wants first. 


datastream 
A sequence of information to be processed by the core. 
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Terminology 


exception 
An error, unusual condition, or external signal that can set a status bit. It may or may 
not cause an interrupt, depending on whether or not the corresponding ene is 
enabled. , | 
execution serialization | 
Instruction issue is halted until all instructions that are currently in progress complete 
execution, all internal pipeline stages and instruction buffers have emptied, and all 
outstanding memory transactions have completed. 
execution stream : 
The combination of instructions and data on which the core Opelaies: 


fetch serialization 


Instruction fetch is halted until all instructions currently in the processor have completed 
execution, including the prefetched instructions waiting to be issued. The machine after 
fetch serialization is said to be completely synchronized. 

half-word | 
A half-word consists of 2 bytes or 16 bits. 


internal bus 
_ The bus connecting the core and system interface unit. 


interrupt 
The act of changing the machine state register and other oe of the machine state in 
response to an Sxcepuon: 
latency 
_ The interval from the time an instruction Betis execution until it pioguers a result that 
is available for use by a subsequent instruction. : | 
little-endian 
- Little-endian byte ordering assigns the lowest address to the lowest-order (rightmost) 
eight bits of the scalar. The little end of the scalar, considered a binary number, comes 
first in memory. 
master 
A device on the bus that requests bus ownership and initiates the bus cycles. 


memory controller 


A functional logic section of the MPC823. Its primary function is to provide the controls 
for the external bus memories and I/O devices. 
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Terminology 


no operation (NOP) 


An instruction whose sole function is to increment the program counter, but which 
affects no changes to any registers or memory. 


scoreboard 


A register tracking system that ensures that values are not pulled from a register before 
they are updated by a previous instruction. 


sequential instruction 
Any instruction that is not a flow control instruction and not ISYNC. 


slave 


A device that responds to the master’s address. A slave receives data on a write cycle 
and gives data to the master on a read cycle. 


snoop 


The act of monitoring external bus activity by alternate bus masters. By snooping these 
external accesses, a core can identify accesses to memory locations that contain dirty 
data and possibly halt activity to supply correct data. 


swap 


Four byte lanes, reversing (lane 0 to lane 3, lane 1 to lane 2, lane 2 to lane 1 and lane 
3 to lane 0). 


tablewalk 


An index value is used to identify an entry point in a tree structure that is traversed until 
a pointer is found. The system walks through a table of pointers to its end. 


TERMINOLOGY 


transaction 


A bus transaction consists of an address transfer (address phase) and data transfers 
(data phase). 


@ 





time-division multiplex (TDM) 
Any serial channel that is divided into channels separated by time. 


watchpoint 
An event that is reported, but does not change the timing of the machine. 


word 
A word consists of 4 bytes or 32 bits. 


writethrough 


Continuous updates, as they occur, of external memory so that cache and memory 
maintain coherency at all times. 
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APPENDIX A 
SERIAL COMMUNICATION PERFORMANCE 


Operating at 25MHz, the MPC823 is designed to support unrestricted operation of the 
high-level data link control (HDLC) or transparent protocol running on the serial 
communication controller at 2.048Mbps. The MPC823 can also support one Ethernet 
channel at 10Mbps and one HDLC or transparent channel at 1Mbps. The physical clocking 
limit of the serial communication controller is higher than the sustained serial bit rate. This 
limit is given as a 1:2.25 ratio between the sync clock, which is a clock generated in the clock 
synthesizer that can be as fast as the 25MHz system clock and the serial clock. For 
example, with a sync clock of 25MHz, the serial communication controller can be clocked at 
11.1MHz. This clocking scheme allows the serial communication controller to handle 
high-speed bursts of data bits for short periods of time subject to the FIFO sizes. 


When the serial communication controller is connected to a time-division multiplexed 
channel using the time-slot assigner on the MPC823, the serial communication controller’s 
physical clocking limit is a 1:2.5 ratio between the sync clock and serial clock. Therefore, the 
serial communication controller can be connected to a 10.0MHz time-division multiplexed 
channel with a 25MHz MPC823. This clocking scheme allows it to handle high-speed bursts 
of data bits for short periods of time subject to the FIFO sizes. Other devices that offer a 
higher HDLC performance than the MPC823 are the Motorola MC68605 1984 CCITT X.25 
LAPB controller and MC68606 CCITT Q.921 multilink LAPD controller. The MC68605 and 
MC68606 perform the full data-link layer protocol and support various transparent modes 
within HDLC-framed operation at speeds of at least 1OMbps. The performance figures listed 
in Table A-1 are for a 25MHz system clock. Notice that, in general, performance scales 
linearly with the frequency so that a combination of protocols over the MPC823’s 
performance limitation at 25MHz can occur at 50MHz. 
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Serial Communication Performance 


A.1 CHANNEL COMBINATIONS 


When operating the multiple HDLC/transparent channel protocol, most of the processing 
load falls on the communication processor module. Protocols other than the multiple HDLC 
and Transparent protocol rely on the hardware support built into the serial channels. 
Combining the serial communication controller and the microcontroller allows you to attain 
throughput rates of up to 8Mbps in HDLC and Transparent mode. 


The multiple channel protocol does not rely on the serial communication controller and 
operates transparently when you perform serial-to-parallel conversion and vice versa. All bit 
manipulation is performed in the microcontroller software or hardware, which causes the 
communication processor module to have a heavier load when operating in multiple channel 
mode. The heavier load occurs even if all time-slots are cone palo to one logical 
channel. 


The following equation and Table A-1 can be used as a guide for calculating the 
communication processor module’s load. The CPM load estimation is not truly linear, so 
there is a gray area near the maximum limit (defined as 1). To determine the exact load, you 
should test your operations on target hardware. The CPM load (L) is approximated by the 
following equation: | 3 


_% 


where: 


Di is the user-targeted data rate for the particular CPM controller or protocol. 


Pi is the CPM performance factor for the particular CPM controller or protocol. See 
Table A-1 for specific values. 


f is the actual CPM system frequency in megahertz. 


Since the equation and table estimates the feasibility of an application used only by the 
CPM, it is your responsibility to verify the application against other issues (pin multiplexing, 
parameter RAM, or microcode availability). The MPC823 Engineer's Toolbox located on the 
MPC823 website (www.mot.com/mpc823) contains a spreadsheet that performs the 
calculation of the CPM load. 
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Table A-1. MPC823 Performance Table 


CONTROLLER/PROTOCOL CPM PERFORMANCE FACTOR 


Ethernet (Half-Duplex) 
Ethernet (Full-Duplex) 
HDLC (Full-Duplex) 
Transparent (Full-Duplex) 
UART (Full-Duplex) 
Async HDLC (Full-Duplex) 


IrDA High-Speed! 
IrDA Medium-Speed* 


IrDA Low-Speed® 
SPI (Half-Duplex) 
SPI Byte 


SPI Word‘ 


Transparent (Full-Duplex) 
UART (Half-Duplex) 
UART (Full-Duplex) 


DMemory->Peripheral 
DPeripheral->Memory 
Memory->Memory 


Memory->Memory (BURST) 


SMemory->Peripheral 
SPeripheral->Memory 


I?C (Half-Duplex) 


22,000 Kbps 
11,000 Kbps 
8,000 Kbps 
8,000 Kbps 
2,400 Kbd 
3,000 Kbps 
16,000 Kbps 


16,000 Kbps 


6,000 Kbps 


500 Kbps 
3,125 Kbps 


1,500 Kbps 
440 Kbd 
220 Kbd 


1,600 KBps 
2,200 KBps 
5,700 KBps 
10,400 KBps 
5,000 KBps 
5,000 KBps 
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PERFORMANCE 


USB High-Speed 24,000 Kbps 





USB Low-Speed 24,000 Kbps 


Same as Transparent Half-Duplex. 

Same as HDLC Half-Duplex. 

Same as Asynchronous HDLC Half-Duplex. 

The SPI controller is in Word mode if the data character is greater than 8 bits in length. 


Bg NS 


IDMA transfer rates are independent of bus cycle length. 
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A.2 EXAMPLE #1 


If the MPC823 is operating at 25MHz with one Ethernet line in half-duplex at 10Mbps, one 
38.4Kbd SMC UART, one 57.6Kbd SMC UART, and one USB at 1.5 Mbps, then the 
following equation applies. 


10 38.4 576 1.5 
39 * 300 + 300 + og += 0-998 


Any calculation such as this, which is close to one, is considered to be in a gray area and 
should be tested with hardware before it is implemented. 


A.3 EXAMPLE #2 


If a block of 512K is transferred by IDMA in single address mode from memory to a 
peripheral, one ASYNC HDLC at 1Mbps, and one SMC UART at 38.4Kbd, then the following 
equation applies when the MPC823 is running at 25MHz. 

512 1000 38.4 


5000 * 3000 * 220 *~ 9-9 
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7 A Note: With IDMA, this process calculates peak communication processor module 

usage, not the sustained rate. By nature, IDMA transfers occur in random 
intervals and are not consistent bit rates when compared to the serial channel 
eae 





A.4 EXAMPLE #3 


For one half-duplex Ethernet channel at 10Mbps and one SMC UART at 115.2Kbd with the 
MPC823 running at 40MHz, the following equation applies. 


10 115.2) | 25_ 
[23 * “pa0 | *ao7 0811 
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APPENDIX B 
MPC823 INSTRUCTION SET 


This section lists the MPC823 instruction set in alphabetical order by mnemonic. Each entry 
includes the instruction formats and a quick reference legend that provides information like 
the level(s) of the PowerPC™ architecture in which the instruction can be found, user- or 
supervisor-level (an instruction is user-level unless the legend specifies otherwise), and the 
instruction formats. The format diagrams show all valid combinations of the instruction 
fields. The architecture specification refers to user- and supervisor-level as problem state 
and privileged state, respectively. 


B.1 INSTRUCTION FORMATS 


Instructions are four bytes long and word-aligned, so when instruction addresses are 
presented to the processor (as in branch instructions) the two low-order bits are ignored. 
Similarly, whenever the processor develops an instruction address, its two low-order bits are 
zero. Bits 0-5 always specify the primary opcode and many instructions also have an 
extended opcode. The remaining bits of the instruction contains one or more fields for the 
different instruction formats. Some instruction fields are reserved or must contain a 
predefined value as shown in the individual instruction layouts. If a reserved field does not 
have all bits cleared, or if a field that must contain a particular value does not contain that 
value, the instruction form is invalid. | 


B.2 SPLIT-FIELD NOTATION 


Some instruction fields occupy more than one contiguous sequence of bits or a contiguous 
sequence of bits used in permuted order. These fields are called split fields. Those split 
fields that represent the concatenation of the sequences from left to right are shown in 
lowercase letters. For instance, spr and tbr are shown in the following table. 


FIELD | DESCRIPTION 
spr (11-20) This field is used to specify a special-purpose register for the mtspr and mfspr instructions. 
tor (11-20) This field is used to specify either the time base lower (TBL) or time base upper (TBU). : 


Split fields that represent the concatenation of the sequences in some order, which need not 
be left to right are shown in uppercase letters. For instance, MB, ME, and SH are shown in 
the following table. 
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MPC823 Instruction Set 


B.3 INSTRUCTION FIELDS 


The table below shows the instruction fields used in the various instruction formats. 


FIELD DESCRIPTION | 


A (30) Absolute address bit. 
The immediate field represents an address relative to the current instruction address (CIA). 
The effective (logical) address of the branch is either the sum of the LI field sign-extended to 
32 bits and the address of the branch instruction or the sum of the BD field sign-extended to 
32 bits and the address of the branch instruction. 
The immediate field represents an absolute address. The effective address (EA) of the branch 


is the LI field sign-extended to 32 bits or the BD field sign-extended to 32 bits. The LI and LD 
fields are sign-extended to 32. 


BD (16-29) Immediate field specifyin 


9a a 14-bit signed two's cope en branch displacement that is 
concatenated on the right with Ob00 and sign-exten 


ed to 32 bits. 


BI (11-15) nt ton is used to specify a bit in the CR to be used as the condition of a branch conditional 
instruction. 


50 6-10) 
SA 8) 
d (1 6-31) Immediate field specifying a 16-bit signed two's complement integer that is sign- -extended to 32 bits. 
ae 
#5610) 


LI (6-29) Immediate field specifying a 24-bit signed two's complement integer that is concatenated on the 
right with Ob00 and sign-extended to 32 bits. 


LK (31) Link bit. 








: Does not update the link register (LR). 


Updates the LR. If the instruction is a branch metrueten the address of the instruction 
following the branch instruction is placed into the L 





MB i288 and | These fields are used in rotate instructions to specify a 32 bit mask. 
NB (16-20) This field is used to specify the number of bytes to move in an immediate string load or store. 


al 


Re (31) Record bit. 
QO Does not update the condition register (CR). 
1. Updates the CR to reflect the result of the operation. 


For integer instructions, CR bits 0—2 are set to reflect the result as a signed quantity and CR 
bit 3 receives a copy of the summary overflow bit, XER[SO]. The besa as an unsigned quantity 
or a bit string can be deduced from the EQ bit. 


Exceptions are referred to as interrupts in the architecture specification.) 


rD (6-10 This field is used to specify a GPR to be used as a destination. 
rS (6-10) This field is used to specify a GPR to be used as a source. 









? 
no 
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MPC823 Instruction Set 


FIELD DESCRIPTION 
SH (16-20) This field is used to specify a shift amount. 


SIMM (16-31) This immediate field is used to specify a 16-bit signed integer. 


SR (12-15) This field is used to specify one of the 16 segment registers. 


TO (6-10) This field is used to specify the conditions on which to trap. 


UIMM (16-31) This immediate field is used to specify a 16-bit unsigned integer. 
Lester ‘be Extended opcode field. 





B.4 NOTATIONS AND CONVENTIONS 


The operation of some instructions is described by a semiformal language or pseudocode. 
The table below contains a list of pseudocode notations and conventions used throughout 
this appendix. 


CONVENTION . 
eS 
a 
a 
[oon are aien 
i 
ane a 
Cae 
assis 


















: 
af 


period) Update. When used as a character of an instruction mnemonic, a period (.) means that the 
instruction updates the condition register field. | 
XERCAl. When used as a character of an instruction mnemonic, a ‘c’ indicates a carry out in 


Extended Precision. 


When used as the last character of an instruction mnemonic, an ‘e’ indicates. the use Gi 
XER[CA] as an operand in the instruction and records a carry out in XER[CA]. 









Overflow. When used as a character of an instruction mnemonic, an ‘o’ indicates the 
record of an overflow in XER[OV] and CRO[SO] for integer instructions. 


Unsigned comparison relations 


Unordered comparison relation 


en AND, OR logical operators 






Pte 9 describe the concatenation of two values (that | is, 010 Il 111 is the same as 


= Exclusive-OR, Equivalence logical operators (for example, ( (aJ b) = (a = -b)) 
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MPC823 Instruction Set 


B. 


NOTATION/ DEFINITION | 
CONVENTION | 


Obnnnn A number expressed in binary format. 


Oxnnnn A number expressed in hexadecimal format. | 


The replication of x, n times (that is, x concatenated to itself n — 1 times). 


mh and (n)1 are special cases. A gescnpton of the special cases follows: 
* (n)O means a field of n bits with each bi 


(n)x 


equal to 0. Thus (5)0 is equivalent to 
Ob00000. 

¢(n)1 means a field of n bits with each bit equal to 1. Thus (5)1 is equivalent to 
0b11111. | 


(rAl0) | |The contents of rA if the rA field has the value 1~—31, or the value 0 if the rA field is 0. 
) The contents of rX 
x[n] nis a bit or field within x, where x is a register 


xn x is raised to the nth power 
ABS(x) Absolute value of x 


CEIL(x) Least integer = x 


Characterization Reference to the setting of status bits in a standard way that is explained in the text. 


CIA Current instruction address. , 
| The 32-bit address of the instruction being described by a sequence of pseudocode. Used 
by relative branches to set the next_instruction address (NIA) and by branch instructions 
with LK = 1 to set the link register. Does not correspond to any architected register. 





= 
i 






Clear Clear the leftmost or rightmost n bits of a register to 0. This operation is used for rotate and 
shift instructions. | 


Clear left and shift left 


Clear the leftmost b bits of a register, then shift the register left by n bits. This operation 


can be used to scale a known non-negative array index by the width of an element. These 
operations are used for rotate and shift instructions. 


Cleared Bits are set to 0. | _ | 


Do loop. 

¢ Indenting shows range. 

¢ “To” and/or “by” clauses specify incrementing an iteration variable. 
e “While” clauses give termination conditions. 





Extract 


Select a field of n bits starting at bit position b in the source register, right or left justify this 
field in the target register, and clear all other bits of the target register to zero. This 
operation is used for rotate and shift instructions. 





EXTS(x) Result of extending x on the left with sign bits 
GPR(x) _ | General-purpose register x | 
if...then...else... Conditional execution, indenting shows range, else is optional. 


Select a field of n bits in the source register, insert this field starting at bit position b of the 
target register, and leave other bits of the target register unchanged. (No simplified 
mnemonic is provided for insertion of a field when operating on double words; such an 
insertion requires more than one instruction.) This operation is used for rotate and shift 
instructions. (Note that simplified mnemonics are reterred to as extended mnemonics in 
the architecture specification.) 


Leave Leave innermost do loop, or the do loop described in leave statement. | 


MASK(x, y) Mask having ones in positions x through y (wrapping if x > y) and zeros elsewhere. 


-MEM(x, y) Contents of y bytes of memory starting at address x. 













| 
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MPC823 Instruction Set — 
NOTATION/ DEFINITION 
CONVENTION 


NIA Next instruction address, which is the 32-bit address of the next instruction to be executed 
(the branch destination) after a successful branch. In pseudocode, a successful branch is 
indicated by assigning a value to NIA. For instructions which do not branch, the next 
instruction address is CIA + 4. Does not correspond to any architected register. 
PowerPC operating environment architecture 
Rotate Rotate the contents of a register right or left n bits without masking. This operation is used 
for rotate and shift instructions. 


Set Bits are set to 1. 
Shift the contents of a register right or left n bits, clearing vacated bits (logical shift). This 


Shift 
= | operation is used for rotate and shift instructions. 


SPR(x) Special-purpose register x 
TRAP Invoke the system trap handler 


Undefined An undefined value. The value may vary from one implementation to another, and from 
one execution to another on the same implementation. 
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UISA PowerPC user instruction set architecture 
PowerPC virtual environment architecture 


The table below describes instruction field notation conventions used in this appendix. 


THE ARCHITECTURE EQUIVALENT 
SPECIFICATION 


BA, BB, BT crbA, crbB, crbD (respectively) 










aE Se Tey eee 
a 
rA, rB, rD, rS (respectively) 
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MPC823 Instruction Set 


Precedence rules for pseudocode operators are summarized in the following table. 


OPERATORS “| ASSOCIATIVITY 
x[n], function evaluation | Left to right 


(n)x orreplication, — . Right to left 
x(n) or exponentiation — . 


Left to right 


o 


= 
i?) 
pa 
vv 
Cc 
© 
ia 
eo) 
ae 
.¢2) 
m 
4. 





Left to right 
Left to right 


=, #, <, <, >, >, <U, >U, ? Left to right 


Left to right 





Operators in the top part of the table above are applied before those in the lower part. 
Operators at the same level in the table associate from left to right, from right to left, or not 
at all. For example, “—” (unary minus) associates from left to right, soa—-b—c=(a—b)-c. 
Parentheses are used to override the evaluation order implied by the table above, or to 
increase clarity and parenthesized expressions are evaluated before serving as operands. 


B.5 THE MPC823 INSTRUCTION SET 


The remainder of this section lists and describes the MPC823 instruction set. The 
instructions are listed in alphabetical order by their mnemonic. 


Note: The execution unit that executes the instruction may not be the same for all 
PowerPC processors. 
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add 


Assembler Syntax 





Operation 


Description 


MOTOROLA 


MPC823 Instruction Set—add 


add rD,rA,rB (OE = 0 Rc = 0) 
add. rD,rA,rB (OE = 0 Rc = 1) 
addo rD,rA,rB (OE = 1 Re = 0) 
addo. rD,rA,rB (OE = 1 Re = 1) 


rD " (rA) + (rB) 


The sum (rA) + (rB) is placed into rD. The add instruction is 
preferred for addition because it sets few status bits. 


Other registers altered: 
LI Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
The CRO field may not reflect the “true” (infinitely precise) 
result if overflow occurs (see XER below). 


[1 XER: 
Affected: SO, OV (if OE = 1) 








POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 


SS OS 
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MPC823 Instruction Set—addc 


addc 





Assembler Syntax addc rD,rA,rB (OE = 0 Rc = 0) 
addc. — rD,rA,rB ia = 0 Rc=1) 
addco rD,rA,rB (OE = 1 Rc = 0) 
addco. rD,rA,rB (OE = 1 Rc = 1) 





Definition Add Carrying 
Operation rD " (rA) + (rB) 
Description The sum (rA) + (rB) is placed into rD. 


Other registers altered: 
Ll Condition Register (CRO field 
Affected: LT, GT, EQ, SO (if Re = 1 
If the CRO field may not reflect the “true” (infinitely 
precise) result if overflow occurs (see XER below 


LJ) XER: 
Affected: CA 


Affected: SO, OV (if OE = 1 


POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 
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MPC823 Instruction Set—adde 


adde 


a 
ww 

Assembler Syntax adde rD,rA,rB (OE = 0 Rc = 0) S 
adde.r D,rA,rB (OE = 0 Rc = 1) G 

addeor D,rA,rB (OE = 1 Re = 0) = 

addeo. rD,rA,rB (OE = 1 Re = 1) = 





Definition Add Extended 
Operation rD " (rA) + (rB) + XER[CA] 
Description The sum (rA) + (rB) + XER[CA] is placed into rD. 


Other registers altered: 
Li Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
The CRO field may not reflect the “true” (infinitely precise) 
result if overflow occurs (see XER below). 


_) XER: 
Affected: CA 


Affected: SO, OV (if OE = 1) 









POWERPC ARCHITECTURE SUPERVISOR 


OPTIONAL 
~ LEVEL LEVEL 


se SSCS 


MOTOROLA MPC823 USER’S MANUAL B-9 









— 
” 
—| 
a) 
Cc 
2) 
—| 
2) 
= 
~*~. 
m 
—| 





MPC823 Instruction Set—addi 


addi 


Assembler Syntax 


Definition : 


Operation 


Description 





addi rD,rA,SIMM) 3 





Add Immediate 


ifrA =O then rD " EXTS(SIMM) 
else rD " rA + EXTS(SIMM 


The sum (rAl0) + SIMM is placed into rD. 


The addi instruction is preferred for addition because it sets few 
status bits. Note that addi uses the value 0, not the contents of 
GPRO, ifrA=0. © 


Other registers altered: 
Li None 7 


Simplified mnemonics: 


| subi frD,rA,value 





equivalent to rD,0,value 


equivalent to rD,rA,disp 


equivalent to 













rD,rA,—value 


POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL 7 LEVEL 
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MPC823 Instruction Set—addic 


addic 


Assembler Syntax addic rD,rA,SIMM) 
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Definition Add Immediate Carrying 
Operation rD " (rA) + EXTS(SIMM) 
Description The sum (rA) + SIMM is placed into rD. 


Other registers altered: 


L) XER: 
Affected: CA 


Simplified mnemonics: 


subic rD,rA,value equivalentto addic rD,rA,—value 










POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL | LEVEL 
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MPC823 Instruction Set—addic. 


addic. 





Assembler Syntax addic. | rD,rA,SIMM) 
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Definition Add Immediate Carrying and:Record 
Operation rD " (rA) + EXTS(SIMM) 
Description _ The sum (rA) + SIMM is placed into rD. 


Other registers altered: 


Li Condition Register (CRO field): 
Affected: LT, GT, EQ, SO 


The CRO field may not reflect the “true” (infinitely precise 
result if overflow occurs (see XER below). 


| OF XERD © 
Affected: CA 


Simplified mnemonics: 


equivalent to rD,rA,—value 





POWERPC ARCHITECTURE SUPERVISOR 
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MPC823 Instruction Set—addis 


addis 


Assembler Syntax addis rD,rA,SIMM) 
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Definition Add Immediate Shifted 


Operation if rA =O then rD " EXTS(SIMM II (16)0) 
else rD " (rA) + EXTS(SIMM II (16)0) 


Description The sum (rAlO) + (SIMM II 0x0000) is placed into rD. 


The addis instruction is preferred for addition because it sets 
few status bits. Note that addis uses the value 0, not the 
contents of GPRO, if rA = 0. 


Other registers altered: 
1 None 


Simplified mnemonics: 






POWERPC ARCHITECTURE | SUPERVISOR | OPTIONAL 
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MPC823 Instruction Set—addme 





addme 
Assembler Syntax addme | rD,rA (OE =0Rc=0) is | 
addme. rD,rA (OE =0Rc=1 
addmeo rD,rA (OE=1Rc=0 
addmeo. rDrA (OE=1Rc=1 





Definition Add to Minus One Extended 
Operation | rD " (rA) + XER[CA] — 1 
Description — 2 ~The sum (rA) + XER[CA] + OXFFFF_FFFF_FFFF_FFFF is 


| | placed into rD. 


Other registers altered: 
Li Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1 
The CRO field may not reflect the “true” (infinitely precise 
result if overflow occurs (see XER below). 


| | L) XER: 
2 . _ Affected: CA 


Affected: SO, OV (if OE = 1 


“pe POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
i a LEVEL — LEVEL 
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MPC823 Instruction Set—addze 


addze 


Assembler Syntax addze rD,rA (OE =0Rc=0) 
addze. rD,rA (OE =0 Rc=1) 
addzeo rD,rA (OE =1Rc=0) 
addzeo. rD,rA (OE =1Rce=1) 
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Definition Add to Zero Extended 
Operation rD " (rA) + XER[CA] 
Description The sum (rA) + XER[CA] is placed into rD. 


Other registers altered: 
_1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
The CRO field may not reflect the “true” (infinitely precise) 
result if overflow occurs (see XER below). 
Ll) XER: 
Affected: CA 


Affected: SO, OV (if OE = 1) 













POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 
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MPC823 Instruction Set—and 
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Asembler Syntax and‘ rA,rS,rB (Re = 0) 
and. rA,rS,rB (Re = 1) 
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Definition And 
Operation rA <— (rs) & (rB) 
Description The contents of rS are ANDed with the contents of rB and the 


result is placed into rA. 


Other registers altered: 


1) Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1 


| : POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
. a _ eo LEVEL LEVEL 
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andc 


Assembler Syntax 





Definition 
Operation 


Description 


MOTOROLA 


MPC823 Instruction Set—andc 


andc rA,rS,rB (Re = 0) 
andc. rA,rS,rB (Re = 1) 


AND with Complement 
rA <— (rS) + 7 (rB) 


The contents of rS are ANDed with the one’s complement of the 
contents of rB and the result is placed into rA. 


Other registers altered: 


_1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 










POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 
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MPC823 Instruction Set—andi. 


andi. 





Assembler Syntax andi. rA,rS,UIMM 
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Definition AND Immediate 
Operation rA < (rS) & ((16)0 || UIMM) 
Description The contents of rS are ANDed with 0x0000 || UIMM and the 


de 2: result is placed into rA. | 


Other registers altered: — 


LI Condition Register (CRO field): 
Affected: LT, GT, EQ, SO 
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oe 
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andis. 


Assembler Syntax 





Definition 
Operation 


Description 


MOTOROLA 


MPC823 Instruction Set—andis. 


andis. fA rS,UIMM 


AND Immediate Shifted 
rA — (rS) + (UIMM II (16)0) 


The contents of rS are ANDed with UIMM || 0xO0000 and the 
result is placed into rA. 


Other registers altered: 


Li Condition Register (CRO field): 
Affected: LT, GT, EQ, SO 
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MPC823 Instruction Set—b | 


b 


Assembler Syntax b target_addr (AA = 0 LK = 0) 
ba target_addr (AA = 1 LK = 0) 
bl target_addr (AA = 0 LK = 1) 
bla target_addr (AA = 1 LK = 1) 





Definition Branch 


Operation if AA then NIA <iea EXTS(LI |] Ob00) 
else NIA <iea CIA + EXTS(LI II Ob00) 
if LK then LR <iea CIA + 4 


Description target_addr specifies the branch target address. 


If AA = 0, then the branch target address is the sum of LI || Ob00 
sign-extended and the address of this instruction. If AA = 1, then 
the branch target address is the value LI || Ob00O sign-extended. 
lf LK = 1, then the effective address of the instruction following 
the branch instruction is placed into the link register. 


Other registers altered: 
Affected: Link Register (LR) (if LK = 1) 
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MPC823 Instruction Set—bc 


bc 


Assembler Syntax bc BO,Bl,target_addr (AA = 0 LK =0 


( ) 
bca BO,Bl,target_addr (AA = 1 LK = 0) 
bcl BO,Bl,target_addr (AA = 0 LK = 1) 
bcla BO,Bl,target_addr (AA = 1 LK = 1) 





Definition Branch Conditional 


Operation m< 32 
if - BO[2] then CTR ¢ CTR—1 
ctr_ok — BO[2] | (BO[3]) 
cond_ok < BO[0] | (CR[BI] = BO[1]) 
if ctr_ok & cond_ok then 
if AA then NIA <-iea EXTS(BD || Ob00) 
else NIA <iea CIA + EXTS(BD II Ob00) 
if LK then LR <iea CIA + 4 


Description The BI field specifies the bit in the condition register (CR) to be 
used as the condition of the branch. The BO field is encoded as 
described in the table below. 


DESCRIPTION 


O000y een the count register (CTR), then branch if the condition is 
0001y |Decrement the CTR, then branch if the condition is FALSE. 

001zy {Branch if the condition is FALSE. 

0100y |Decrement the CTR, then branch if the condition is TRUE. 


‘ny 
ay 


NOTE: In this table, z indicates a bit that is ignored. The z bits should be cleared. 
The y bit has a hint about whether a conditional branch is likely to be taken. 
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MPC823 Instruction Set—bc 
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LEVEL | LEVEL 
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target_addr specifies the branch target address. 


lf AA = 0, the branch target address is the sum of BD || Ob00 
sign-extended and the address of this instruction. If AA = 1, the 
branch target address is the value BD || Ob00 sign-extended. If 
LK = 1, the effective address of the instruction following the 
branch instruction is placed into the link register. 


Other registers altered: 
Affected: Count Register (CTR) (if BO[2] = 0) 
Affected: Link Register (LR) (if LK = 1) 
Simplified mnemonics: | 









bit arget equivalent to | be 12,0,target 
|bne r2,target equivalent to | be 44,10,target 
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Assembler Syntax bectr BO,BI (LK = 0) S 
bectrl BO,BI (LK = 1) O 

cc 
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Definition Branch Conditional to Count Register 


Operation cond_ok <- BO[0] | (CR[BI] = BO[1]) 
if cond_ok then 
NIA <iea CTR || ObOO 
if LK then LR <iea CIA + 4 


Description The BI field specifies the bit in the condition register to be used 
as the condition of the branch. The BO field is encoded as 
described in the table below. 


| BO DESCRIPTION 


Decrement the CTR, then branch if the condition is TRUE. 


NOTE: In this table, z indicates a bit that is ignored. The z bits should be cleared. 
The y bit has a hint about whether a conditional branch is likely to be taken. 














The branch target address is CTR II Ob00. 


lf LK = 1, the effective address of the instruction following the 
branch instruction is placed into the link register. 
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MPC823 Instruction Set—bcctr 


If the “decrement and test CTR’ option is specified (BO[2] = 0), 
the instruction form is invalid. 


@ 


Other registers altered: 
Affected: Link Register (LR) (if LK = 1) 
Simplified mnemonics: | 


pret [| equvatentto [ect [12.0 
lbnectr_|er2_ | equivalentto | bectr | 410 
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MPC823 Instruction Set—bclr 


bclr 
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Assembler Syntax belr BO,BI (LK = 0) S 
belrl BO,BI (LK = 1) o 
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Definition Branch Conditional to Link Register 


Operation m< 32 
if = BO[2] then CTR « CTR-—-1 
ctr_ok <— BO[2] | ((CTR # 0) © BO[S3}) 
cond_ok < BO[O] | (CR[BI] = BO[1]) 
if ctr_ok & cond_ok then 
NIA €—iea LR [| Ob00 
if LK then LR <iea CIA + 4 


Description The BI field specifies the bit in the condition register to be used 
as the condition of the branch. The BO field is encoded as 
described in the table below. 


aor 
ay 


NOTE: In this table, z indicates a bit that is ignored. The z bits should be cleared. 
The y bit has a hint about whether a conditional branch is likely to be taken. 
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MPC823 Instruction Set—bclir 


The branch target address is LR[O-29] || ObO0O. 
lf LK = 1, then the effective address of the instruction following 
the branch instruction is placed into the link register. 


ra 


Other registers altered: 
Affected: Count Register (CTR) (if BO[2] = 0) 
Affected: Link Register (LR) (if LK = 1) 
Simplified mnemonics: | 


[ptr || equivalentto [boty | 12,0 
fbnete [er2 | equivalentto [ber [410 
ber [160 
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MPC823 Instruction Set—cmp 


cmp 


Assembler Syntax cmp crfD,L,rA,rB 





Definition Compare 
Operation a < EXTS(rA) 
b < EXTS(rB) 


ifa <b then c < 06100 

else if a > b then c <— 06010 

else c — O0b001 

CR[4 * crfD—4 * crfD + 3] <— c ll XER[SO] 


Description ) The contents of rA are compared with the contents of rB treating 
the operands as signed integers. The result of the comparison is 
placed into CR field crfD. 


Other registers altered: 


[1 Condition Register (CR field specified by operand crfD): 
Affected: LT, GT, EQ, SO 


Simplified mnemonics: 


empd [Ave | eauivalentio [emp [OA 
empw [rSrAr@| eauvalentio [emp [S07Ar 













| POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
| LEVEL . LEVEL 


eG 
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MPC823 Instruction Set—cmpi 


cmpi 








Definition Compare Immediate 


Operation a < (rA) 
ifa < EXTS(SIMM) then c — 0b100 
else if a > EXTS(SIMM) then c ~— 0b010 
elsec << 0b001 | 7 
CRI[4 * crfD—4 * crfD + 3] — c || XER[SO] 


Description The contents of rA are compared with the sign-extended value 
of the SIMM field, treating the operands as signed integers. The 
result of the comparison is placed into CR field erfD. 


Other registers altered: 


[4 Condition Register (CR field specified by operand crfD): 
Affected: LT, GT, EQ, SO 


implified mnemonics: 


rA,value equivalent to 
cr3,rA,value | equivalent to 














3,0,rA,value 


|empdi | |empi | 0,1,rA,value 
jempwi jempi_ 









POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 
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MPC823 Instruction Set—cmpl 


cmpl 


Assembler Syntax cmpl crfD,L,rA,rB 


_ 
Lu 
w“ 
= 
© 
= 
oO 
_— 
co 
- 
c¢2) 
= 


Be 





Definition Compare Logical 
Operation a<crA 
b<+rB 


ifa <U b then c — 06100 

else if a >U b then c < 0b010 

else c — O0b001 

CR[4 * crfD—-4 « crfD + 3] < cll XER[SO] 


Description The contents of rA are compared with the contents of rB, 
treating the operands as unsigned integers. The result of the 
comparison is placed into CR field crfD. 


Other registers altered: 
[1 Condition Register (CR field specified by operand crfD): 
Affected: LT, GT, EQ, SO 


Simplified mnemonics: 


empld |rArB | equivalentto [empl _|0,1,rA,rB | 
[emplw | er3,rArB | equivalentto empl |3,0,rA,rB 









POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 


eS 
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MPC823 Instruction Set—cmpli 


cmpli | 





Assembler Syntax cmpli crfD,L,rA,UIMM 





Definition Compare Logical Immediate 


Operation a<(rA 
if a <U ((16)0 |] UIMM) then c — 0b100 


else if a >U ((16)0 II UIMM) then c — 0b010 


else c — Ob001 
CR[4 * crfD—4 * crfD + 3] < cll XER[SO] 


Description The contents of rA are compared with Ox0000I! UIMM, treating 
the operands as unsigned integers. The result of the comparison 


is placed into CR field crfD. 


Other registers altered: 
[1 Condition Register (CR field specified by operand crfD): 
Affected: LT, GT, EQ, SO 


Simplified mnemonics: 


a | [emplwi | cr3,rA,value- equivalent to }cmpli_ 3,0,rA,value 





POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
~ LEVEL LEVEL 
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MPC823 Instruction Set—cntlzw 


cntizw 


Assembler Syntax cntlzw rA,rS (Re = 0) 
cntlzw. rA,rS (Re = 1) 





Definition Count Leading Zeros Word 


Operation n<O 
do while n < 32 
if rS[n] = 1 then leave 
nen+1 
rAcn 


Description A count of the number of consecutive zero bits starting at bit 0 of 
rS is placed into rA. This number ranges from 0 to 32, inclusive. 


Other registers altered: 


[1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO(if Re = 1) 


If Rc = 1, then LT is cleared in the CRO field. 


POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL | LEVEL | 


SC 
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MPC823 Instruction Set—crand 


crand 





Assembler Syntax crand crobD,crbA,crbB 





Definition ondition Register AND 
Operation CR[crbD] <— CRicrbA] & CR[icrbB] 


The bit in the condition register specified by crbA is ANDed with 
the bit in the condition register specified by crbB. The result is 
placed into the condition register bit specified by crbD. 


Other registers altered: 


[i Condition Register: 
Affected: Bit specified by operand crbD 


POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL , LEVEL 
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MPC823 Instruction Set—crandc 


crandc 
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Definition Condition Register AND with Complement 
Operation CR[crbD] < CR{[crbA] & = CR[crbB] 
Description The bit in the condition register specified by crbA is ANDed with 


the complement of the bit in the condition register specified by 
crbB and the result is placed into the condition register bit 
specified by crbD. 


Other registers altered: 


1 Condition Register: 
Affected: Bit specified by operand crbD 








POWERPC ARCHITECTURE SUPERVISOR OPTIONAL 
LEVEL LEVEL 
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MPC823 Instruction Set—creqv 


creqv 


Assembler Syntax 


Definition 


Operation 


B-34 





creqv crbD,crbA,crbB | 





Condition Register Equivalent 
CR[crbD] < CR[icrbA] = CR[crbB] 


The bit in the condition register specified by crbA is XORed wi 
the bit in the condition register specified by crbB and the 
complemented result is placed into the condition register bit 
specified by crbD. 


Other registers altered: 


LY Condition Register: 
Affected: Bit specified by operand croD 


Simplified mnemonics: 


crbD,crbD, 


equivalent to 





crbD 









POWERPC ARCHITECTURE 
LEVEL 


SUPERVISOR 


OPTIONAL 
LEVEL 
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MPC823 USER’S MANUAL MOTOROLA 


MPC823 Instruction Set—crnand 


crnand 


Assembler Syntax crnand crobD,crbA,crbB 
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Definition Condition Register NAND 
Operation CR[erbD] — - (CR[cerbA] & CR[crbB)}) 


The bit in the condition register specified by crbA is ANDed with 
the bit in the condition register specified by crbB and the 
complemented result is placed into the condition register bit 
specified by crbD. 


Other registers altered: 


1 Condition Register: 
Affected: Bit specified by operand crbD 





POWERPC ARCHITECTURE SUPERVISOR |; OPTIONAL 
of LEVEL LEVEL 


ser 





MOTOROLA MPC823 USER’S MANUAL B-35 


MPC823 Instruction Set—crnor 


crnor 


Assembler Syntax crnor — _cerbD,crbA,crbB 
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Definition Condition Register NOR 
Operation CRicrbD] < - (CR[erbA] | CR[crbB]}) 


The bit in the condition register specified by crbA is ORed with 
the bit in the condition register specified by crbB and the 
complemented result is placed into the condition register bit 
specified by crbD. 


Other registers altered: | 


Li Condition Register: 
Affected: Bit specified by operand crbD 


Simplified mnemonics: 


crbD,crbA, 








POWERPC ARCHITECTURE SUPERVISOR 


OPTIONAL 
LEVEL LEVEL 
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MPC823 Instruction Set—cror 


Cror 


Assembler Syntax cror crbD,crbA,crbB 





Definition Condition Register OR 
Operation CRi[crbD] <— CR[crbA] | CRicrbB] 
Description The bit in the condition register specified by crbA is ORed with 


the bit in the condition register specified by crbB. The result is 
placed into the condition register bit specified by crbD. 


Other registers altered: 


L} Condition Register: 
Affected: Bit specified by operand crbD 


Simplified mnemonics: 


crbD,crbA equivalent to ror 








crbD,crbA, 
crbA 













POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 
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MPC823 Instruction Set—crorc 





crore 


crore crbD,crbA,crbB - 





peration 


escription 


B-38 


ondition Register OR with Complement | 
R[crbD] < CR[crbA] | = CR[crbB] 


The bit in the condition register specified by crbA is ORed with 
the complement of the condition register bit specified by crbB 


and the result is placed into the condition register bit specified by 
crbD. 


Other registers altered: 


LI Condition Register: 
Affected: Bit specified by operand crbD 










POWERPC ARCHITECTURE SUPERVISOR 


OPTIONAL 
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MPC823 Instruction Set—crxor 


Crxor 


Assembler Syntax crxor crbD,crbA,crbB 





Definition Condition Register XOR 
Operation CR[crbD] <— CR[crbA] © CRicrbB] 
Description The bit in the condition register specified by crbA is XORed with 


the bit in the condition register specified by crbB and the result 
is placed into the condition register specified by crbD. 


Other registers altered: 


L1 Condition Register: 
Affected: Bit specified by crbD 


Simplified mnemonics: 


equivalent to crbD,crbD, 
q crbD 








POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
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MPC823 Instruction Set—dcbf 


dcbf 


AssemblerSyntax 


Definition 
Operation 


Description 


B-40 





dcbf — rA,rB 





Data Cache Block Flush 
EA is the sum (rAlO) + (rB). 


The debf instruction invalidates the block in the data cache 
addressed by EA, copying the block to memory first, if there is 
any dirty data in it. If the processor is a multiprocessor 
implementation and the block is marked coherency-required, the 
processor will, if necessary, send an address-only broadcast to 
other processors. The broadcast of the debf instruction causes 
another processor to copy the block to memory, if it has dirty 
data, and then invalidate the block from the cache. 


The action taken depends on the memory mode associated with 
the block containing the byte addressed by EA and on the state 
of that block. The list below describes the action taken for the 
various states of the memory coherency attribute (M bit). 


e Coherency required 


Li Unmodified block—tnvalidates copies of the block in the 
data caches of all processors. 

1 Modified block—Copies the block to memory. Invalidates 
copies of the block in the data caches of all processors. 

Li Absent block—lf modified copies of the block are in the 
data caches of other processors, causes them to be 
copied to memory and invalidated in those data caches. 
lf unmodified copies are in the data caches of other 
processors, causes those copies to be invalidated in 
those data caches. 


e Coherency not required 


Li Unmodified block—lInvalidates the block in the 
processor's data cache. 


MPC823 USER’S MANUAL MOTOROLA 


MPC823 Instruction Set—dcbf 


L} Modified block—Copies the block to memory. Invalidates 
the block in the processor’s data cache. 

Ll Absent block (target block not in cache)—No action is 
taken. 


The function of this instruction is independent of the write- 
through, write-back and caching-inhibited/allowed modes of the 
block containing the byte addressed by EA. 
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This instruction may be treated as a load from the addressed 
byte with respect to address translation and memory protection. 
It may also be treated as a load for referenced and changed bit 
recording except that referenced and changed bit recording may 
not occur. 


© 





Other registers altered: 
e None 






POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 
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MPC823 Instruction Set—dcbi 


dcbi 


Asembler Syntax dcbi rA,rB 
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Definition Data Cache Block Invalidate 
Operation EA is the sum (rAlO) + (rB). 
Description The action taken is dependent on the memory mode associated 


with the block containing the byte addressed by EA and on the 
state of that block. The list below describes the action taken if the 
block containing the byte addressed by EA is or is not in the 
cache. 


e Coherency required 


11 Unmodified block—Invalidates copies of the block in the 
data caches of all processors. 

LL} Modified block—Invalidates copies of the block in the 
data caches of all processors. (Discards the modified 


nnantante \ 
WVJIILYI twee] 


[} Absent block—lf copies of the block are in the data 
caches of any other processor, causes the copies to be 
invalidated in those data caches. (Discards any modified 
contents.) 


e Coherency not required 


LI Unmodified block—Invalidates the block in the 
processor's data cache. 

lL} Modified block—Invalidates the block in the processor’s 
data cache. (Discards the modified contents.) 

Li Absent block (target block not in cache)—No action is 
taken. 
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MPC823 Instruction Set—dcbi 


When data address translation is enabled, MSR[DR] = 1, and the 
virtual address has no translation, a DSI exception occurs. The 
function of this instruction is independent of the write-through 
and caching-inhibited/allowed modes of the block containing the 
byte addressed by EA. This instruction operates as a store to the 
addressed byte with respect to address translation and 
protection. The referenced and changed bits are modified 
appropriately. This is a supervisor-level instruction. 
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Other registers altered: 
e None 


a 
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Assembler Syntax debst rA,rB 
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Definition Data Cache Block Store 
Operation EA is the sum (rAl0) + (rB). 
Description The debst instruction executes as follows: 


e If the block containing the byte addressed by EA is in 
coherency-required mode, and a block containing the byte 
addressed by EA is in the data cache of any processor and 
has been modified, the writing of it to main memory is 
initiated. 


e lf the block containing the byte addressed by EA is in 
coherency-not-required mode, and a block containing the 
byte addressed by EA is in the data cache of this processor 


and has been modified, the writing of it to main memory is 
al 


initiated. 
The function of this instruction is independent of the write- 
through and caching-inhibited/allowed modes of the block 
containing the byte addressed by EA. The processor treats this 
instruction as a load from the addressed byte with respect to 
address translation and memory protection. It may also be 
treated as a load for referenced and changed bit recording 
except that referenced and changed bit recording may not occur. 


Other registers altered: 
e None 


| _ | POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
os | LEVEL LEVEL 
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MPC823 Instruction Set—dcbt 


debt 


Assembler Syntax dcbt rA,rB 
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Definition Data Cache Block Touch 
Operation EA is the sum (rAl0) + (rB). 
Description This instruction is a hint that performance will probably be 


improved if the block containing the byte addressed by EA is 
fetched into the data cache, because the program will probably 
soon load from the addressed byte. The hint is ignored if the 
block is caching-inhibited. Executing debt does not cause the 
system alignment error handler to be invoked. 


This instruction may be treated as a load from the addressed 
byte with respect to address translation, memory protection, and 
reference and change recording, except that no exception 
occurs in the case of a translation fault or protection violation. 


The program uses the debt instruction to request a cache block 
fetch before it is actually needed by the program. The program 
can later execute load instructions to put data into registers. 
However, the processor is not obliged to load the addressed 
block into the data cache. 


Other registers altered: 
Li None 
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dcbtst 





Assembler Syntax dcbtst rA,rB 
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Definition Data Cache Block Touch for Store 
Operation EA is the sum (rAlO) + (rB). 
Description This instruction is a hint that performance will be improved if the 


block containing the byte addressed by EA is fetched into the 

_ data cache, because the program will probably soon store into 
the addressed byte. The hint is ignored if the block is caching- 
inhibited. Executing dcbtst does not cause the system 
alignment error handler to be invoked. 


This instruction operates as a load from the addressed byte with 
respect to address translation and protection, except that no 
exception occurs in the case of a translation fault or protection 
violation. Also, if the referenced and changed bits are recorded, 
they are recorded as if the access was a load. 


. The program uses debtst to request a cache block fetch to 
guarantee that a subsequent store will be to a cached location. 
: 7 s The program can later execute store instructions to put data into 
memory. However, the processor is not obliged to load the 
addressed cache block into the data cache. 


Other registers altered: 
L1 None 
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MPC823 Instruction Set—dcbz 


dcbz 


Assembler Syntax dcbz rA,rB 





Definition Data Cache Block Set to Zero 
Operation EA is the sum (rAlO) + (rB). 
Description The dcbz instruction executes as follows: 


L1 Ifthe cache block containing the byte addressed by EA is 
in the data cache, all bytes are cleared. 

(1 If the cache block containing the byte addressed by EA is 
not in the data cache and the corresponding page is 
caching-allowed, the cache block is allocated in the data 
cache (without fetching the block from main memory), 
and all bytes are cleared. 

(1 If the page containing the byte addressed by EA is in 
caching-inhibited or write-through mode, either all bytes 
of main memory that correspond to the addressed cache 
block are cleared or the alignment exception handler is 
invoked. The exception handler clears all bytes in main 
memory that corresponds to the addressed cache block. 

1 Ifthe cache block containing the byte addressed by EA is 
in coherency-required mode, and the cache block exists 
in the data cache(s) of any other processor(s), it is kept 
coherent in those caches. 
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MPC823 Instruction Set—dcbz 


This instruction is treated as a store to the addressed byte with 
respect to address translation, memory protection, referenced 
and changed recording and the ordering enforced by eieio or by 
the combination of caching-inhibited and guarded attributes for 
a page. 
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Other registers altered: © 
Li None | 
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divw 


Assembler Syntax 





Definition 


Operation 


Description 


MOTOROLA 


MPC823 Instruction Set—divw 
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wn 
divw rD,rA,rB (OE = 0 Rc = 0) S 
divw. rD,rA,rB (OE = 0 Rc = 1) Q 
divwo rD,rA,rB (OE = 1 Rc =0) = 
divwo. rD,rA,rB (OE = 1 Re = 1) = 


SB 





Divide Word 


dividend < (rA) 
divisor < (rB) 
rD < dividend + divisor 


The dividend is the contents of rA. The divisor is the contents of 
rB. The 32-bit quotient is formed and placed in rD. The 
remainder is not supplied as a result. 


Both the operands and the quotient are interpreted as signed 
integers. The quotient is the unique signed integer that satisfies 
the equation—dividend = (quotient * divisor) + r where 0 <r < 
Idivisorl (if the dividend is non-negative), and —Idivisor|] <r < 0 (if 
the dividend is negative). 


lf an attempt is made to perform any of the divisions— 
0x8000_0000 + —1or <anything> + 0O—then the contents of rD 
are undefined, as are the contents of the LT, GT, and EQ bits of 
the CRO field (if Rc = 1). In this case, if OE = 1 then OV is set. 


The 32-bit signed remainder of dividing the contents of rA by the 
contents of rB can be computed as follows, except in the case 
that the contents of rA = —231 and the contents of rB = —1. 


divw rD,rA,rB # rD = quotient 
mullw rD,rD,rB # rD = quotient * divisor 
subf rD,rD,rA # rD = remainder 
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MPC823 Instruction Set—divw 
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Other registers altered: 

Li Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 

1) XER: 
Affected: SO, OV (if OE = 1) 
The setting of the affected bits in the XER is 
mode-independent, and reflects overflow of the 32-bit 
result. 
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divwu 


Assembler Syntax 





Definition 


Operation 


Description 
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MPC823 Instruction Set—divwu 
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divwu rD,rA,rB (OE = 0 Rc = 0) S 
divwu. rD,rA,rB (OE = 0 Rc = 1) o 
divwuo rD,rA,rB (OE = 1 Re = 0) = 
divwuo. rD,rA,rB (OE = 1 Re = 1) = 





SB | 


Divide Word Unsigned 


dividend < (rA) 
divisor < (rB) 
rD < dividend + divisor 


The dividend is the contents of rA. The divisor is the contents of 
rB. A 32-bit quotient is formed. The 32-bit quotient is placed into 
rD. The remainder is not supplied as a result. 


Both operands and the quotient are interpreted as unsigned 
integers, except that if Rc = 1 the first three bits of CRO field are 
set by signed comparison of the result to zero. The quotient is 
the unique unsigned integer that satisfies the equation— 
dividend = (quotient * divisor) + r (where O < r < divisor). If an 
attempt is made to perform the division—<anything> -+- O—then 
the contents of rD are undefined as are the contents of the LT, 
GT, and EQ bits of the CRO field (if Rc = 1). In this case, if OE = 
1 then OV is set. 3 


The 32-bit unsigned remainder of dividing the contents of rA by 
the contents of rB can be computed as follows: 


divwu rD,rA,rB # rD = quotient 
mullw rD,rD,rB # rD = quotient * divisor 
subf rD,rD,rA # rD = remainder 
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MPC823 Instruction Set—divwu 
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Other registers altered: 
Li Condition Register (CRO field): 
Affected: LT, GT, EQ, SO(if Re = 1) 
Ly) XER: | 
Affected: SO, OV(if OE = 1) 
The setting of the affected bits in the XER is mode- 
independent, and reflects overflow of the 32-bit result. 
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eciwxX 


Assembler Syntax eCiwXx rD,rA,rB 
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Definition External Control In Word Indexed 


Operation ifrA=Othenb<0O 
else b< (rA) 
EA < b + (rB) 


paddr <- address translation of EA 

send load word request for paddr to device identified by 
EAR[RID] 

rD <— word from device 


Description The eciwx instruction allows the system designer to map special 
devices in an alternative way. The MMU translation of the EA is 
not used to select the special device, as it is used in most 
instructions such as loads and stores. Rather, it is used as an 
address operand that is passed to the device over the address 
bus. Four other pins (the burst and size pins on the 60x bus) are 
used to select the device; these four pins output the 4-bit 
resource ID (RID) field that is located in the EAR register. The 
eciwx instruction also loads a word from the data bus that is 
output by the special device. 


The eciwx instruction and the EAR register can be very efficient 
when mapping special devices such as graphics devices that 
use addresses as pointers. 


EA is the sum (rAlO) + (rB). 


A load word request for the physical address (referred to as real 
address in the architecture specification) corresponding to EA is 
sent to the device identified by EAR[RID], bypassing the cache. 
The word returned by the device is placed in rD. EAR[E] must be 
1. If it is not, a DSI exception is generated. 


MOTOROLA MPC823 USER’S MANUAL B-53 


MPC823 Instruction Set—eciwx 


EA must be a multiple of four. If it is not, one of the following 
occurs: 


e Asystem alignment exception is generated. 
¢ ADSI exception is generated (possible only if EAR[E] = 0). 
e The results are boundedly undefined. 
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The eciwx instruction is supported for EAs that reference 

-.memory segments in which SR[T] = 1 and for EAs mapped by 
the DBAT registers. If the EA references a direct-store segment 
(SR[T] = 1), either a DSI exception occurs or the results are 
boundedly undefined. However, note that the direct-store facility 
is being phased out of the architecture and will not likely be 
supported in future devices. Thus, software should not depend 
on its effects. 





If this instruction is executed when MSR[DR] = 0 (real 
addressing mode), the results are boundedly undefined. This 
instruction is treated as a load from the addressed byte with 
‘respect to address translation, memory protection, referenced 
and changed bit recording, and the ordering performed by eieio. 
This instruction is optional in the PowerPC architecture. 


Other registers altered: 
e None 
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eCOWwx 


Assembler Syntax 





Definition 


Operation 


Description 


MOTOROLA 


MPC823 Instruction Set—ecowx 


@COWX rs,rA,rB 


External Control Out Word Indexed 


ifrA=0Othenb<0O 

else b< (rA) 

EA <b + (rB) 

paddr <- address translation of EA 

send store word request for paddr to device identified by 
EAR[RID] 

send rS to device 


The ecowx instruction and the EAR register can be very efficient 
when mapping special devices such as graphics devices that 
use addresses as pointers. 


EA is the sum (rAlO) + (rB). A store word request for the physical 
address corresponding to EA and the contents of rS are sent to 
the device identified by EAR[RID], bypassing the cache. EAR[E] 
must be 1, if it is not, a DSI exception is generated. EA must be 
a multiple of four. If it is not, one of the following occurs: 


e Asystem alignment exception is generated. 
e ADSI exception is generated (possible only if EAR[E] = 0). 
e The results are boundedly undefined. 


The ecowx instruction is supported for effective addresses that 
reference memory segments in which SR[T] = 0, and for EAs 
mapped by the DBAT registers. If the EA references a direct- 
store segment (SR[T] = 1), either a DSI exception occurs or the 
results are boundedly undefined. However, note that the direct- 
store facility is being phased out of the architecture and will not 
likely be supported in future devices. Thus, software should not 
depend on its effects. 
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MPC823 Instruction Set—ecowx 


If this instruction is executed when MSR[DR] = 0 (real 
addressing mode), the results are boundedly undefined. This 
instruction is treated as a store from the addressed byte with 
respect to address translation, memory protection, nd 
referenced and changed bit recording, and the ordering 
performed by eieio. This instruction is optional in the PowerPC 
architecture. 7 
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Other registers altered: 
e None 
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Definition Enforce In-Order Execution of I/O 


Description The efeto instruction provides an ordering function for the effects 
of load and store instructions executed by a processor. These 
loads and stores are divided into two sets, which are ordered 
separately. The memory accesses caused by a debz instruction 
are ordered like a store. The two sets are as follows: 


e Loads and stores to memory that are caching-inhibited, 
guarded, and stores to memory that is write-through 
required. The eieio instruction controls the order in which the 
accesses are performed in main memory. It ensures that all 
applicable memory accesses caused by instructions 
preceding the eieio instruction have completed with respect 
to main memory before any applicable memory accesses 
caused by instructions following the eleio instruction access 
main memory. It acts as a barrier that flows through the 
memory queues to main memory, preventing the reordering 
of memory accesses across the barrier. No ordering is 
performed for dcbz if the instruction causes the system 
alignment error handler to be invoked. All accesses in this set 
are ordered as a single set—that is, there is not one order for 
loads and stores to caching-inhibited and guarded memory 
and another order for stores to write-through required 
memory. 


e Stores to memory that have all of the following attributes— 
caching-allowed, write-through not required, and memory- 
coherency required. The eieio instruction controls the order 
in which the accesses are performed with respect to 
coherent memory. It ensures that all applicable stores 
caused by instructions preceding the eieio instruction have 
completed with respect to coherent memory before any 
applicable stores caused by instructions following the eieio 

instruction complete with respect to coherent memory. With 
the exception of dcbz, eieio does not affect the order of 
cache operations (whether caused explicitly by execution of 
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a cache management instruction, or implicitly by the cache 

coherency mechanism). The eieio instruction does not affect 
the order of accesses in one set with respect to accesses in 
the other set. 


ra | 


The eleio instruction may complete before memory accesses 
caused by instructions preceding the eieio instruction have been 
performed with respect to main memory or coherent memory as 
appropriate. 
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The eleio instruction is intended for use in managing shared 
data structures, in accessing memory-mapped I/O, and in 
preventing load/store combining operations in main memory. For 
the first use, the shared data structure and the lock that protects 
it must be altered only by stores that are in the same set (1 or 2; 
see previous discussion). For the second use, eieio can be 
thought of as placing a barrier into the stream of memory 
accesses issued by a processor, such that any given memory 
access appears to be on the same side of the barrier to both the 
processor and the I/O device. Because the processor performs 
store operations in order to memory that is designated as both 
caching-inhibited and guarded, the eleio instruction is needed 
for such memory only when loads must be ordered with respect 
to stores or with respect to other loads. 





Note that the eieio instruction does not connect hardware 
considerations to it, such as multiprocessor implementations 
that send an eleio address-only broadcast (useful in some 
designs). For example, if a design has an external buffer that 


f hatt Ar affin tHaa H 
reorders loads and stores for better bus efficie: ncy, ihe Sieis 


broadcast signals to that buffer that previous loads/stores 
(marked caching-inhibited, guarded, or write-through required) 
must complete before any following loads/stores (marked 
caching-inhibited, guarded, or write-through required). 


Other registers altered: 
Li None 
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eqv 


Assembler Syntax eqv rA,rS,rB (Rc = 0) 
eqv. rA,rS,rB (Rc = 1) 
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Definition Equivalent 
Operation rA <— (rS) = (rB) 
Description The contents of rS are XORed with the contents of rB and the 


complemented result is placed into rA. 


Other registers altered: 


[1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
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MPC823 Instruction Set—extsb 


extsb 
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Assembler Syntax extsb 
extsb. 


rA,rS (Re = 1) 





Definition Extend Sign Byte 


Operation © rs[24] 
rA[24-31] — rS[24-31] 
rA[0—23] < (24 


Description The contents of rS[24-31] are placed into rA[24-31]. Bit 24 of rS 
is placed into rA[0-23]. 


Other registers altered: 


Li Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1 
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extsh 


Assembler Syntax extsh rA,rs (Re = 0) 
extsh. rA,rS (Re = 1) 
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Definition Extend Sign Half Word 


Operation S <— rS[16] 
rA[16-31] — rS[16-31] 
rA[0-15] — (16)S 


Description The contents of rS[16-31] are placed into rA[16-31]. Bit 16 of rS 
is placed into rA[O—15]. 


Other registers altered: 


1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
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Icbi 
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Assembler Syntax icbi rA,rB- 
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Definition Instruction Cache Block Invalidate 
Description EA is the sum (rAlO) + (rB). 


If the block containing the byte addressed by EA is in coherency- 
required mode, and a block containing the byte addressed by EA 
is in the instruction cache of any processor, the block is made 

_ invalid in all such instruction caches, so that subsequent 
references cause the block to be refetched. 


If the block containing the byte addressed by EA is in coherency- 
not-required mode, and a block containing the byte addressed 
by EA is in the instruction cache of this processor, the block is 
made invalid in that instruction cache, so that subsequent 
references cause the block to be refetched. The function of this 
instruction is independent of the write-inrougn, wiite-back, and 
caching-inhibited/allowed modes of the block containing the byte 
addressed by EA. 


This instruction is treated as a load from the addressed byte with 
respect to address translation and memory protection. It may 
also be treated as a load for referenced and changed bit 
recording except that referenced and changed bit recording may 
not occur. Implementations with a combined data and instruction 
cache treat the icbi instruction as a no-op, except that they may 
invalidate the target block in the instruction caches of other 
processors if the block is in coherency-required mode. 


The icbi instruction invalidates the block at EA (rAl0 + rB). If the 
processor is a multiprocessor implementation and the block is 
marked coherency-required, the processor will send an address 
only broadcast to other processors causing those processors to 
invalidate the block from their instruction caches. 
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For faster processing, many implementations will not compare 
the entire EA (rAlO + rB) with the tag in the instruction cache. 
Instead, they will use the bits in the EA to locate the set that the 
block is in, and invalidate all blocks in that set. 


Other registers altered: 
11 None 


INSTRUCTION SET 
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isync 
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Definition Instruction Synchronize 


Description The tsync instruction provides an ordering function for the 
effects of all instructions executed by a processor. Executing an 
isync instruction ensures that all instructions preceding the the 
isync instruction have completed before the isync instruction 
completes, except that memory accesses caused by those 
instructions need not have been performed with respect to other 
processors and mechanisms. It also ensures that no subsequent 
instructions are initiated by the processor until after the isynce 
instruction completes. Finally, it causes the processor to discard 
any prefetched instructions, with the effect that subsequent 
instructions will be fetched and executed in the context 
established by the instructions preceding the isync instruction. 
The isync instruction has no effect on the other processors or on 
their caches. This instruction is context synchronizing. 


Context synchronization is necessary after certain code 
sequences that perform complex operations within the 
processor. These code sequences are usually operating system 
tasks that involve memory management. For example, if an 
instruction “A” changes the memory translation rules in the 
memory management unit (MMU), the isync instruction should 
be executed so that the instructions following instruction “A” will 
be discarded from the pipeline and refetched according to the 
new translation rules. This instruction is context synchronizing. 


Other registers altered: 
Li None 
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Ibz 


Assembler Syntax lbz rD,d(rA) 


| 
Lud 
a 
=z 
OQ 
j_ 
. © 
— 
co 
_— 
an 
= 





© 





Definition Load Byte and Zero 


Operation ifrA=Othenb<0O 
else b < (rA) 
EA «+ b+EXTS(qd) 
rD — (24)0 || MEM(EA, 1) 


Description EA is the sum (rAl0) + d. The byte in memory addressed by EA 
is loaded into the low-order eight bits of rD. The remaining bits 
in rD are cleared. 


Other registers altered: 
L1 None 
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MPC823 Instruction Set—Ibzu 


lbzu 


Assembler Syntax 


Definition 


Operation 


Description 
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lbzu rD,d(rA) 





Load Byte and Zero with Update 


EA < (rA) + EXTS(d). 
rD + (24)0 Il MEM(EA, 1 
rA< EA 


EA is the sum (rA) + d. The byte in memory addressed by EA is 
loaded into the low-order eight bits of rD. The remaining bits in 
rD are cleared. EA is placed into rA. If rA = 0, or rA = rD, the 
instruction form is invalid. 


Other registers altered: 
Li None 7 
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[bzux 


Assembler Syntax lbzux rD,rA,rB 





Definition Load Byte and Zero with Update Indexed 
Operation EA < (rA) + (rB) 
rD < (24)0 || MEM(EA, 1) 
rA< EA 
Description EA is the sum (rA) + (rB). The byte in memory addressed by EA 


is loaded into the low-order eight bits of rD. The remaining bits 
in rD are cleared. EA is placed into rA. If rA = 0 or rA=rD, the 
instruction form is invalid. 


Other registers altered: 
Ll None : 
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MPC823 Instruction Set—Ibzx 


Ibzx 


Assembler Syntax 


Definition 


Operation 


Description 





lbzx rD,rA,r 





Load Byte and Zero Indexed 


if rA=0Othenb<0O 
else b <— (rA 

EA <— b + (rB) 

rD < (24)0 I| MEM(EA, 1 


EA is the sum (rAl0O) + (rB). The byte in memory addressed by 
EA is loaded into the low-order eight bits of rD. The remaining 
bits in rD are cleared. 


Other registers altered: 
Ll None 
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lha 


Assembler Syntax Ilha rD,d(rA) 
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Definition Load Half Word Algebraic 


Operation ifrA=Othenb<0 
else b < (rA) 
EA + b+ EXTS(qd) 
rD — EXTS(MEM(EA, 2)) 


Description EA is the sum (rAl0) + d. The half word in memory addressed by 
EA is loaded into the low-order 16 bits of rD. The remaining bits 
inrD are filled with a copy of the most-significant bit of the loaded 
half word. | 


Other registers altered: 
Ll None | 
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lhau 





ssembler Syntax lhau rD,d(rA) 
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efinition oad Half Word Algebraic with Update 
peration EA < (rA) + EXTS(d 
rD — EXTS(MEM(EA, 2 
rA<EA 
escription EA is the sum (rA) + d. The half word in memory addressed by 


EA is loaded into the low-order 16 bits of rD. The remaining bits 
inrD are filled with a copy of the most-significant bit of the loaded 
half word. EA is placed into rA. If rA =0 orrA = rD, the instruction 
form is invalid. | 


Other registers altered: 
Li None 
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Ihaux 


Assembler Syntax lnaux rD,rA,rB 
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Definition Load Half Word Algebraic with Update Indexed 
Operation EA < (rA) + (rB) 
rD — EXTS(MEM(EA, 2)) 
rA< EA 
Description EA is the sum (rA) + (rB). The half word in memory addressed 


by EA is loaded into the low-order 16 bits of rD. The remaining 
bits in rD are filled with a copy of the most-significant bit of the 
loaded half word. EA is placed into rA. If rA =0 or rA=rD, the 
instruction form is invalid. 


Other registers altered: 
LI None 
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Assembler Syntax lhax rD,rA,r 
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Definition Load Half Word Algebraic Indexed 

Operation ifrA=0thenb<0 | s a4 4 
else b < (rA) 
EA < b + (rB) 


rD — EXTS(MEM(EA, 2 


Description EA is the sum (rAl0) + (rB). The half word in memory addressed 
by EA is loaded into the low-order 16 bits of rD. The remaining 
bits in rD are filled with a copy of the most-significant bit of the 
loaded half word. 


Other registers altered: 
| 1 None 
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Ihbrx 


Assembler Syntax Inbrx rD,rA,rB 
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Definition Load Half Word Byte-Reverse Indexed 
Operation ifrA=Othenb<0O 

else b < (rA) 

EA < b + (rB) 


rD + (16)0 Il MEM(EA + 1, 1) I! MEM(EA, 1) 


Description EA is the sum (rAlQ) + (rB). Bits O—7 of the half word in memory 
addressed by EA are loaded into the low-order eight bits of rD. 
Bits 8—15 of the half word in memory addressed by EA are 
loaded into the subsequent low-order eight bits of rD. The 
remaining bits in rD are cleared. 


The PowerPC architecture cautions programmers that some 
implementations of the architecture may run the Ihbrx 
instructions with greater latency than other types of load 
instructions. 


Other registers altered: 
1 None 
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MPC823 Instruction Set—lhz 


hz 


Assembler Syntax lhz rD,d(rA) 





Definition Load Half Word and Zero 
Operation ifrA=0thenb<0 

else b < (rA) 

EA «+b + EXTS(d) 


rD < (16)0 Il MEM(EA, 2) 


Description _. EAis the sum (rAl0) + d. The half word in memory addressed by 
EA is loaded into the low- order 16 bits of rD. The remaining bits 
in rD are cleared. 


Other fagicters altered: 
1 None 
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Definition Load Half Word and Zero with Update 
Operation EA <— rA + EXTS(d) 
rD — (16)0 [| MEM(EA, 2) 
rA< EA 
Description EA is the sum (rA) + d. The half word in memory addressed by 


EA is loaded into the low-order 16 bits of rD. The remaining bits 
in rD are cleared. EA is placed into rA. If rA = 0 or rA=rD, the 
instruction form is invalid. 


Other registers altered: 
Ll None 





POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 


es ee ee 





MOTOROLA MPC823 USER’S MANUAL — B-75 


QO 


— 
” 
paar 
8 
Cc 
© 
= 
2) 
= 
.o2) 
m 
— 





MPC823 Instruction Set—Ihzux 


Ihzux 


Assembler Syntax Inzux rD,rA,rB 





Definition Load Half Word and Zero with Update Indexed 
Operation EA < (rA) + (rB) 
rD — (16)0 Il MEM(EA, 2) 
rA< EA 
Description | EA is the sum (rA) + (rB). The half word in memory addressed 


by EA is loaded into the low-order 16 bits of rD. The remaining 
bits in rD are cleared. EA is placed into rA. If rA=0 orrA=rD, 
the instruction form is invalid. 


Other registers altered: 
[1 None 
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Definition Load Half Word and Zero Indexed 
Operation if rA =0 thenb< 0 

else b < (rA) 

EA <— b + (rB) 


rD < (16)0 II MEM(EA, 2) 


Description EA is the sum (rAl0) + (rB). The half word in memory addressed 
by EA is loaded into the low-order 16 bits of rD. The remaining 
bits in rD are cleared. 


Other registers altered: 
L1 None 
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Definition Load Multiple Word 


Operation if rA =0 then b< 0 
else b < (rA) 
EA <b + EXTS(d) 
r<rD 
do while r < 31 
GPR(r) — MEM(EA, 4) 
re-r+1 
EA<EA+4 


Description EA is the sum (rAl0) + d. n= (82 —rD). n consecutive words 
starting at EA are loaded into GPRs rD through r31. 


EA must be a multiple of four. If it is not, either the system 
alignment exception handler is invoked or the results are 
boundedly undefined. If rA is in the range of registers specified 
to be loaded, including the case in which rA = 0, the instruction 
form is invalid. | 


Note that, in some implementations, this instruction is likely to 
have a greater latency and take longer to execute, perhaps 
much longer, than a sequence of individual load or store 
instructions that produce the same results. 


Other registers altered: 
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Assembler Syntax Iswi rD,rA,NB 
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Definition Load String Word Immediate 


Operation ifrA =O then EA< 0 
else EA < (rA) 
if NB = 0 then ne 32 
else ne NB 
rerD-1 
I< 32 
do while n> 0 
if i = 32 then 
r<r+1 (mod 32) 
GPR(r) < 0 
GPR(r)[i-i + 7] — MEM(EA, 1) 
ici+8 
if i = 32 theni << O 
FA <EA+1 
nen-1 


Description EA is (rAlO). Let n= NB if NB #0, n= 32 if NB =0; nis the number 
of bytes to load. Let nr= CEIL(n + 4); nris the number of 
registers to be loaded with data. 


n consecutive bytes starting at EA are loaded into GPRs rD 
through rD + nr— 1. Bytes are loaded left to right in each register. 
The sequence of registers wraps around to r0 if required. If the 
4 bytes of register rD + nr—1 are only partially filled, the unfilled 
low-order byte(s) of that register are cleared. If rA is in the range 
of registers specified to be loaded, including the case in which rA 
= 0, the instruction form is invalid. Under certain conditions (for 
example, segment boundary crossing) the data alignment 
exception handler may be invoked. 
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Note that, in some implementations, this instruction is likely to 
have greater latency and take longer to execute, perhaps much 
longer, than a sequence of individual load or store instructions 
that produce the same results. 
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Other registers altered: 
fy None 
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Assembler Syntax 





Definition 


Operation 


Description 
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ISwx rD,rA,rB 
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Load String Word Indexed 


ifrA=0thenb<0O 
else b < (rA) | 
EA < b + (rB) 

n< XER[25-31] 
re rD—-1 

I< 32 

rD < undefined 

do while n> 0 

if i = 32 then 
r<r+1 (mod 32) 
GPR(r) <— 0 
GPR(nr)[i + 7] <— MEM(EA, 1) 
ici+8 

if i = 32 theni — 0 
FA< EA+1 
nen-1 


EA is the sum (rAl0) + (rB). Let n= XER[25—31]; nis the number 
of bytes to load. Let nr= CEIL(n + 4); nris the number of 
registers to receive data. If n> 0, nN consecutive bytes starting at 
EA are loaded into GPRs rD through rD + nr—-1. 


Bytes are loaded left to right in each register. The sequence of 
registers wraps around through r0 if required. If the four bytes of 
rD + nr—1 are only partially filled, the unfilled low-order byte(s) 
of that register are cleared. If n= 0, the contents of rD are 
undefined. 


If rA or rB is in the range of registers specified to be loaded, 
including the case in which rA = 0, either the system illegal 
instruction error handler is invoked or the results are boundedly 
undefined. If rD = rA or rD = rB, the instruction form is invalid. If 
rD and rA both specify GPRO, the form is invalid. 
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Under certain conditions (for example, segment boundary 
crossing) the data alignment exception handler may be invoked. 
Note that, in some implementations, this instruction is likely to 
have a greater latency and take longer to execute, perhaps 
much longer, than a sequence of individual load or store 
instructions that produce the same results. 


re | 


Other registers altered: 
Li None 
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Assembly Syntax 





Definition 


Operation 


_ Description 
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Load Word and Reserve Indexed 


ifrA=Othenb<0O 

else b < (rA) 

EA < b + (rB) 

RESERVE < 1 

RESERVE_ADDR < physical_addr(EA) 
rD — MEM(EA,4) 


EA is the sum (rAl0) + (rB). The word in memory addressed by 
EA is loaded into rD. 


This instruction creates a reservation for use by a store word 
conditional indexed (stwex.) instruction. The physical address 
computed from EA is associated with the reservation, and 
replaces any address previously associated with the reservation. 
EA must be a multiple of four. If it is not, either the system 
alignment exception handler is invoked or the results are 
boundedly undefined. When the RESERVE bit is set, the 
processor enables hardware snooping for the block of memory 
addressed by the RESERVE address. 


If the processor detects that another processor writes to the 
block of memory it has reserved, it clears the RESERVE bit. The 
stwcx. instruction will only do a store if the RESERVE bit is set. 
The stwex. instruction sets the CRO[EQ] bit if the store was 
successful and clears it if it failed. The lwarx and stwex. 
combination can be used for atomic read-modify-write 
sequences. 
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MPC823 Instruction Set—Iwarx 


Note that the atomic sequence is not guaranteed, but its failure 
can be detected if CRO[EQ] = 0 after the stwex. instruction. 


Other registers altered: 
Li None 
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Iworx 


Assembler Syntax lwbrx rD,rA,rB 
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Definition Load Word Byte-Reverse Indexed 


Operation ifrA=Othenb<0 
else b < (rA) 
EA < b + (rB) 
rD — MEM(EA + 3, 1) IT MEM(EA + 2, 1) I| MEM(EA + 1, 1) Il 
MEM(EA, 1) 


Description EA is the sum (rAl0) + rB. Bits 0-7 of the word in memory 
addressed by EA are loaded into the low-order 8 bits of rD. Bits 
8—15 of the word in memory addressed by EA are loaded into the 
subsequent low-order 8 bits of rD. Bits 16-23 of the word in 
memory addressed by EA are loaded into the subsequent 
low-order eight bits of rD. Bits 24-31 of the word in memory 
addressed by EA are loaded into the subsequent low-order 8 bits 
of rD. The MPC823 may run the Iwbrx instructions with greater 
latency than other types of load instructions. 


Other registers altered: 
Li None 








POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL ts LEVEL 


a 


MOTOROLA MPC823 USER’S MANUAL B-85 


= 
”n 
— 
=e 
Cc 
© 
= 
Oo 
= 
op) 
m 
a 





MPC823 Instruction Set—Iwz 


lwz 


Assembler Syntax 


efinition 


peration 


escription 
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WZ rD,d(rA) 





Load Word and Zero 


ifrA=0thenb< 0 
else b < (rA) 

EA + b+ EXTS(d) 
rD — MEM(EA, 4) 


EA is the sum (rAlO) + d. The word in memory addressed by EA 
is loaded into rD. | | 


ther registers altered: | 
Li} None 
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Definition Load Word and Zero with Update 
Operation EA <— rA + EXTS(d) 
rD — MEM(EA, 4) 
rA<— EA 
Description EA is the sum (rA) + d. The word in memory addressed by EA is 


loaded into rD. EA is placed into rA. If rA = 0, or rA = rD, the 
instruction form is invalid. 


Other registers altered: 
L1 None 
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MPC823 Instruction. Set—Iwzux 


Iwzux 


Assembler Syntax 


Definition 


Operation 


Description 
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lwzux rD,rA,rB | 





Load Word and Zero with Update Indexed 


EA < (rA) + (rB) 
rD ~— MEM(EA, 4) 
rA< EA 


EA is the sum (rA) + (rB). The word in memory addressed by EA 
is loaded into rD. EA is placed into rA. If rA = 0, or rA =rD, the 
instruction form is invalid. 


Other registers altered: 
Li None 
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Definition Load Word and Zero Indexed 
Operation ifrA=0thenb< 0 

else b< (rA) 

FA<b+rB 


rD — MEM(EA, 4) 


Description EA is the sum (rAlO) + (rB). The word in memory addressed by 
EA is loaded into rD. 


Other registers altered: 
Li None 
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MPC823 Instruction Set—mcrf 





merf 


Assembler Syntax 


merf crnfD,crfS 





Definition 
Operation 


Description 
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Move Condition Register Field 
CR[4 * erfD—4 * crfD + 3] — CR[4 * crfS—4 * crfS + 3] 


The contents of condition register field crfS are copied into 
condition register field crfD. All other condition register fields 
remain unchanged. 


Other registers altered: 


Ll Condition Register (CR field specified by operand crfD): 
Affected: LT, GT, EQ, SO 
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POWERPC ARCHITECTURE 
LEVEL 
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Definition Move to Condition Register from XER 


Operation CR[4 * crfD—4 * crfD + 3] — XER[O-3] 
XER[O-3] <— Ob0000 


Description The contents of XER[O-3] are copied into the condition register 
field designated by crfD. All other fields of the condition register 
remain unchanged. XER[O-3] is cleared. 


Other registers altered: 
1 Condition Register (CR field specified by operand crfD): 
Affected: LT, GT, EQ, SO 


 XER[O-3] 
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Definition Move from Condition Register , 
Operation rD< CR 
Description The contents of the condition register (CR) are placed into rD. 


| Other registers altered: | 
1 None : 
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Definition Move from Machine State Register 
Operation rD — MSR 
Description The contents of the MSR are placed into rD. This is a Supervisor 


level instruction. 


Other registers altered: 
Li None 
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MPC823 Instruction Set—mfspr 


mfspr 


Assembler Syntax 





mfspr rD,SPR 





NOTE: *This is a split field. 


Definition 


Operation 


Description 
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Move from Special-Purpose Register 


n< spr[5—9] Il spr[O—4] 
rD — SPR(n) 


In the PowerPC UISA, the SPR field denotes a special-purpose 
register, encoded as shown in the table below. The contents of 
the designated special-purpose register are placed into rD. 


REGISTER NAME 


DECIMAL SPR[0-4] 





NOTE: *The order of the two 5-bit halves of the SPR number is reversed 
compared with the actual instruction coding. 


If the SPR field contains any value other than one of the values 
shown in Table 9 (and the processor is in user mode), one of the 
following occurs: 


e The system illegal instruction error handler is invoked. 


e The system supervisor-level instruction error handler is 
invoked. 


e The results are boundedly undefined. 


Other registers altered: | 
e None 
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MPC823 Instruction Set—mfspr 


Simplified mnemonics: 


imiser [O [| eqitalontto _[miepr [vO 
mtr |r| equvatntto _[mfopr [10.6 
imfow [x0 | equvalontio __|mtspr [v0.9 


In the PowerPC OEA, the SPR field denotes a special-purpose 
register, encoded as shown in the table below. The contents of 
the designated SPR are placed into rD. SPR[0] = 1 if and only if 
reading the register is supervisor-level. Execution of this 
instruction specifying a defined and supervisor-level register 
when MSR[PR] = 1 will result in a priviledged instruction type 
program exception. 









If MSR[PR] = 1, the only effect of executing an instruction with 
an SPR number that is not shown in the table below and has 
SPR[O] = 1 is to cause a supervisor-level instruction type 
program exception or an illegal instruction type program 
exception. For all other cases, MSR[PR] = 0 or SPR[O] = 0. If the 
SPR field contains any value that is not shown in the table, either 
an illegal instruction type program exception occurs or the 
results are boundedly undefined. 


Other registers altered: — 
e None 


NAME 


[20009 | oseco [ter 
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SO 


Supervisor 


DAR 
DEC 
00000 11010 SRRO Supervisor 
EIE 
EID 
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MPC823 Instruction Set—mfspr 
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REGISTER 
NAME 
| DECIMAL | SPRIS-9] SPR[0—4] 














ACCESS 


00100 11101 LCTRL2 Supervisor 







158 00100 11110 ICTRL Supervisor 
159 00100 44441 Supervisor 


Supervisor 









Supervisor 


[ser [toons [sooo | c-a0r 
a 
a 
= 
[rer 


10001 Supervisor 


Supervisor 
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MPC823 Instruction Set—mfspr 


REGISTER ACCESS 
NAME 
DECIMAL SPR[0—4] 
794 


11010 MD_AP Supervisor 




















795 11011 | = MD_EPN Supervisor 
796 11100 M_TWB — Supervisor 
797 11101 MD_TWC Supervisor 


| SPrIs-o] 
Ce 


1. The order of the two 5-bit halves of the SPR number is reversed 
compared with actual instruction coding. 


2. Sets the EE Bit in the MSR. 
Clears the EE Bit in the MSR. 
4. Development Support (Debug) Register. 


11001 


Supervisor 





For mtspr and mfspr instructions, the SPR number coded in 
assembly language does not appear directly as a 10-bit binary 
number in the instruction. The number coded is split into two 5-bit 
halves that are reversed in the instruction, with the high-order five bits 
appearing in bits 16—20 of the instruction and the low-order five bits 
in bits 11-15. 
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NOTE: mfspr is supervisor-level only if SPR[O] = 1. 
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Definition Move from Time Base 


Operation n < tbr[5—9] II tbr[O—4] 
if n= 268 then 
rD <— TBL 
else if n = 269 then 
rD < TBU 


REGISTER ACCESS 
NAME 
DECIMAL | TBR[5-9] | TBR[O-4] 
01000 01100 TB Read User 
01000 01101 TBU Read 


NOTE: *The order of the two 5-bit halves of the TBR number is reversed. 










Description If the TBR field contains any value other than one of the values 
shown in the table above, then one of the following occurs: 


e The system illegal instruction error handler is invoked. 


e The system supervisor-level instruction error handler is 
invoked. 


e The results are boundedly undefined. 


It is important to note that some implementations may implement 
mftb and mfspr identically, therefore, a TBR number must not 
match an SPR number. 
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Other registers altered: 
e None 


Simplified mnemonics: 
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Definition Move to Condition Register Fields 


Operation mask <— (4)(CRM[O)) II (4)(CRM[1]) II... (4)(CRM[7] 
CR < (rS & mask) | (CR & a mask 


Description The contents of rS are placed into the condition register under 
control of the field mask specified by CRM. The field mask 
identifies the 4-bit fields affected. Let i be an integer in the range 
0-7. If CRM(i) = 1, CR field i (CR bits 4 * i through 4 * i + 3) is set 
to the contents of the corresponding field of rS. 


Note that updating a subset of the eight fields of the condition 
register may have substantially poorer performance on some 
implementations than updating all of the fields. 


Other registers altered: 
Li CR fields selected by mask 


Simplified mnemonics: 
mtcr rS equivalent to mtcrf OxFF,rS 
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Definition Move to Machine State Register 
Operation MSR < (rS) 
Description The contents of rS are placed into the MSR. This is a supervisor 


level instruction. It is also an execution synchronizing instruction 
except with respect to alterations to the POW and LE bits. 


In addition, alterations to the MSR[EE] and MSR[RI] bits are 
effective as soon as the instruction completes. Thus if MSR[EE] 
= 0 and an external or decrementer exception is pending, 
executing an mtmsr instruction that sets MSR[EE] = 1 will cause 
the external or decrementer exception to be taken before the 
next instruction is executed, if no higher priority exception exists. 


Other registers altered: 
11 MSR 
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MPC823 Instruction Set—mtspr 


mtspr 


Assembler Syntax 


NOTE: “*This is a split field. 


Definition 


Operation 


Description 
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mtspr SPR,rS 





Move to Special-Purpose Register 


n< spr[5—9] || spr[O-4] 
SPR(n) << rS_ 


In the PowerPC UISA, the SPR field denotes a special-purpose 
register, encoded as shown in the following table. The contents 
of rS are placed into the designated special-purpose register. 


REGISTER 


NAME 
DECIMAL } SPRIS-o] SPR[0-4] 


00000 00001 XER 





pg 00000 01001 


NOTE: *The order of the two 5-bit halves of the SPR number is reversed compared 
with actual instruction coding. 


If the SPR field contains any value other than one of the values 
shown in the table above, and the processor is operating in user 
mode, one of the following occurs: 


e The system illegal instruction error handler is invoked. 
e The system supervisor instruction error handler is invoked. 
e The results are boundedly undefined. 


Other registers altered: 
¢ See table above. 
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Simplified mnemonics: 


mixer [rD_ | equivalentto | mtspr_| 144 
tir |r| equivalentto | mtspr_| 8,10 
mtctr_ [rD_ | equivalentto[mtspr_[9,rD_ 


In the PowerPC OEA, the SPR field denotes a special-purpose. 
register, encoded as shown in the following table. The contents 
of rS are placed into the designated special-purpose register. 
For this instruction, SPRs TBL and TBU are treated as separate 
32-bit registers; setting one leaves the other unaltered. 
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The value of SPR[O] = 1 if and only if writing the register is a 
supervisor-level operation. Execution of this instruction 
specifying a defined and supervisor-level register when 
MSR[PR] = 1 results in a privileged instruction type program 
exception. 


If MSR[PR] = 1 then the only effect of executing an instruction 
with an SPR number that is not shown in the following table and 
has SPR[0] = 1 is to cause a privileged instruction type program 
exception or an illegal instruction type program exception. For all 
other cases, MSR[PR] = 0 or SPR[O] = 0, if the SPR field 
contains any value that is not shown in the table, either an illegal 
instruction type program exception occurs or the results are 
boundedly undefined. 


Other registers altered: 


REGISTER ACCESS 
NAME 


00000 10010 DSISR 
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| DECIMAL 









REGISTER 
NAME 


spr’ — ACCESS 
[sonic | somo 

[4 [_eor00 | to000 [owen 
Pst 

ps2 





Supervisor 


4144 
— 145 
146 
147 
148 
— 149 
284 01000 TB Write 









Supervisor 


Supervisor 





Supervisor 
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REGISTER ACCESS 


SPR’ 
NAME 
Tosca [ sone | somo 


1. . The order of the two 5-bit halves of the SPR number is reversed. For 
mtspr and mfspr instructions, the SPR number coded in assembly 
language does not appear directly as a 10-bit binary number in the 
instruction. The number coded is split into two 5-bit halves that are 
reversed in the instruction, with the high-order five bits appearing in 
bits 16-20 of the instruction and the low-order five bits in bits 11-15... 


. Sets EE Bit in MSR. 
3. Clears EE Bit in MSR. 
Development Support (Debug) Register. 
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NOTES: 









POWERPC ARCHITECTURE SUPERVISOR OPTIONAL 
LEVEL LEVEL 
uewoce = dS 


NOTE: mtspr is supervisor-level only if SPR[O] = 1. 


MOTOROLA MPC823 USER’S MANUAL B-105 





MPC823 Instruction Set—mulhw 





mulhw 


Assembler Syntax 


mulhw rD,rA,rB (Re = 0) 
mulhw. rD,rA,rB (Re = 1) 





Definition 


Operation 


Description 


B-106 


Multiply High Word 3 


prod[0-63] ¢+rA*rB 
~rD © prod[0-31] : 


The 64 -bit product is formed from the contents of rA and rB. The 
high-order 32 bits of the 64-bit product of the operands are 
placed into rD. Both the operands and the product are 
interpreted as signed integers. This instruction may execute 
faster on some implementations if rB contains the operand 
having the smaller absolute value. 


Other registers altered: 
[1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1 













POWERPC ARCHITECTURE SUPERVISOR 


OPTIONAL 
LEVEL LEVEL 


se 
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MPC823 Instruction Set—mulhwu 


mulhwu 


Assembler Syntax mulhwu rD,rA,rB(Re = 0) 
mulhwu. rD,rA,rB(Re = 1) 
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Definition Multiply High Word Unsigned 


Operation prodjO-63] < rA * rB 
rD — prod[0-—31 ] 


Description The 32-bit operands are the contents of rA and rB. The high 
order 382 bits of the 64-bit product of the operands are placed into 
rD. Both the operands and the product are interpreted as 
unsigned integers, except that if Rc = 1 the first three bits of CRO 
field are set by signed comparison of the result to zero. This 
instruction may execute faster on some implementations if rB 
contains the operand having the smaller absolute value. 


Other registers altered: 


Q) Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
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MPC823 Instruction Set—mulli 


mulll 


Assembler Syntax mulli rD,rA,SIMM 





Definition Multiply Low Immediate 


Operation prod[0—48] — (rA) * SIMM 
rD <— prod[16-48] 


Description The first operand is (rA). The 16-bit second operand is the value 
| | of the SIMM field. The low-order 32-bits of the 48-bit product of 

the operands are placed into rD. Both the operands and the 
product are interpreted as signed integers. The low-order 32 bits 
of the product are calculated independently of whether the 
operands are treated as signed or unsigned 32-bit integers. This 
instruction can be used with mulhdx or mulhwx to calculate a 
full 64-bit product. 


Other registers altered: 
4 None — 
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mullw 


Assembler Syntax 





Definition 
Operation 


Description 


MOTOROLA 





MPC823 Instruction Set—mullw 


mullw rD,rA,rB (OE = 0 Rc = 0) S 
mullw. rD,rA,rB (OE = 0 Rc = 1) © 
mullwo rD,rA,rB (OE = 1 Re = 0) = 
mullwo. rD,rA,rB (OE = 1 Re = 1) = 


© 





Multiply Low Word 
r<—rA*rB 


The 32-bit operands are the contents of rA and rB. The low- 
order 32 bits of the 64-bit product (rA) * (rB) are placed into rD. 
The low-order 32 bits of the product are the correct 32-bit 
product for 32-bit implementations. The low-order 32-bits of the 
product are independent of whether the operands are regarded 
as signed or unsigned 32-bit integers. If OE = 1, then OV is set 
if the product cannot be represented in 32 bits. Both the 
operands and the product are interpreted as signed integers. 


Note that this instruction may execute faster on some 
implementations if rB contains the operand having the smaller 
absolute value. 


Other registers altered: 

1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1). 
The CRO field may not reflect the “true” (infinitely precise) 
result if overflow occurs (see XER below). 

L} XER: 
Affected: SO, OV (if OE = 1). 
The setting of the affected bits in the XER is mode- 
independent, and reflects overflow of the 32-bit result. 


.. POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 


SS 
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MPC823 Instruction Set—nand 


nand 





I 
© 


Assembler Syntax nand rA,rs,rB (Re 
nand. YA,rS,rB (Re 
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Definition NAND 
Operation rA — 7 ((rS) & (rB) 
Description The contents of rS are ANDed with the contents of rB and the 


complemented result is placed into rA. nand with rS = rB can be 
used to obtain the one's complement. 


Other registers altered: 


me : | 1 Condition Register (CRO field): 
Affected: LT,,GT, EQ, SO (if Re = 1) 


POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL] FORM 
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MPC823 Instruction Set—neg 


neg 

Assembler Syntax neg rD,rA (OE =0 Rc=0) 
neg. rD,rA (OE =0Rc=1) 
nego rD,rA (OE =1Rc=0) 
nego. rD,rA (OE =1 Rce= 1) 





Definition Negate 
Operation rD «+ -(rA) +1 
Description The value 1 is added to the complement of the value in rA, and 


the resulting two’s complement is placed into rD. If rA contains 
the most negative 32-bit number (Ox8000_0000), the result is the 
most negative number and, if OE = 1, OV is set. 


Other registers altered: 
L} Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
Li XER: 
Affected: SO OV (if OE = 1) 
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MPC823 Instruction Set—nor 





NOFr 


Assembler Syntax 


nor rA,rS,rB (Re 
nor. rA,rS,rB (Re 


0) 
1) 





Definition 
Operation 


Description 


B-112 


NOR 
rA <— - ((rS) | (rB)) 


The contents of rS are ORed with the contents of rB and the 
complemented result is placed into rA. nor with rS = rB can be 
used to obtain the one’s complement. 


Other registers altered: 


1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1 


Simplified mnemonics: 






not equivalent to nor rA rs 
Daa Se a ee ee Se eee en 
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MPC823 Instruction Set—or 


Or 


Assembler Syntax or rA,rS,rB (Re = 0) 
or. rA,rS,rB (Re = 1) 





Definition OR 
Operation rA <— (rS) | (rB) 
Description The contents of rS are ORed with the contents of rB and the 


result is placed into rA. The simplified mnemonic mr (shown 
below) demonstrates the use of the or instruction to move 
register contents. 


Other registers altered: 
Li Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
Simplified mnemonics: 











POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 


SC 
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MPC823 Instruction Set—orc 


Ore 


Definition 
Operation 


Description 


B-114 





orc rA,rS,rB (Rc = 0) 
ore. rA,rS,rB (Re = 1) 





OR with Complement 
rA<(rS)|-A(rB) 


The contents of rS are ORed with the complement of the 
contents of rB and the result is placed into rA. 


Other registers altered: 


1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
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MPC823 Instruction Set—ori 


Assembler Syntax ori rA,rS,UIMM 
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Definition OR Immediate 
Operation rA <— (rS) | ((16)0 I| UIMM) 
Description The contents of rS are ORed with 0x0000!! UIMM and the result 


is placed into rA. The preferred no-op (an instruction that does 
nothing) is ori 0,0,0. 


Other registers altered: 


Li None 
Simplified mnemonics: 


nop | | __equivalentio fori [0.0.0 
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LEVEL LEVEL 


ik | ee eR ee Ee 
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MPC823 Instruction Set—oris 


oris 


Assembler Syntax 


Definition 
Operation 


Description 


B-116 





oris rA,rS,UIMM 


SOS eR 





OR Immediate Shifted 
rA <— (rS) | (UIMM II (16)0 | 


The contents of rS are ORed with UIMM || 0x0000 and the result 
is placed into rA. 


Other registers altered: 
1 None 





POWERPC ARCHITECTURE SUPERVISOR 
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MPC823 Instruction Set—rfi 
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Definition Return from Interrupt 


Operation MSR[16-23, 25-27, 30-31] — SRR1[16-23, 25-27, 30-31] 
NIA <iea SRRO[O-29] II ObOO 


Description Bits SRR1[0,5-9,16-31] are placed into the corresponding bits of 
the MSR. If the new MSR value does not enable any pending 
exceptions, then the next instruction is fetched, under control of 
the new MSR value, from the address SRRO[0-29] || ObOO. If the 
new MSR value enables one or more pending exceptions, the 
exception associated with the highest priority pending exception 
is generated; in this case the value placed into SRRO by the 
exception processing mechanism is the address of the 
instruction that would have been executed next had the 
exception not occurred. Note that an implementation may define 

_ addtional MSR bits, and in this case, may also cause them to be 
saved to SRR1 from MSR on an exception and restored to MSR 
from SRR1 on an rfi. This is a supervisor-level, context 
synchronizing instruction. 


Other registers altered: 
Li MSR 






POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
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MPC823 Instruction Set—rlwimi 


rlwimi 


Assembler Syntax rlwimi rA,rS,SH,MB,ME (Rc = 0) 
rlwimi. rA,rS,SH,MB,ME (Re = 1) 





Definition Rotate Left Word Immediate then Mask Insert 


Operation n< SH 
, r< ROTL(FS, n) 
m <— MASK(MB, ME) 
rA< (r&m)/ (rA& =m) 


Description The contents of rS are rotated left the number of bits specified 
by operand SH. A mask is generated having 1 bits from bit MB 
through bit ME and 0 bits elsewhere. The rotated data is inserted 
into rA under control of the generated mask. 


Note that rlwimi can be used to insert a bit field into the contents 
of rA using the methods shown below: 
[4 To insert an n-bit field, that is left-iustified rS, into rA 
starting at bit position b, set SH = 32 — b, MB =b, and 
ME = (b+n)-—1. 
1 To insert an n-bit field, that is right-justified in rS, into rA 
starting at bit position b, set SH = 32 — (b +n), MB =b, 
and ME = (b +n) —1. 


Other registers altered: 
[3 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO(if Re = 1) 
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MPC823 Instruction Set—rlwimi 


Simplified mnemonics: 


nse win 





rA,rS,n,b (n > 0) equivalent to 


rA,rS,32 — (b+ n),b,(b +n) —1 
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MPC823 Instruction Set—rlwinm 


rlwinm 


@ 


Assembler Syntax Ss rlwinm ~—_—srA,rS,SH,MB,ME (Rc = 0) 
rlwinm. rA,rS,SH,MB,ME (Re = 1) 
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Definition Rotate Left Word Immediate then AND with Mask 


Operation n< SH 
r< ROTL(rS, n) 
m <— MASK(MB, ME) 
rAc—r&m 


Description The contents of rS are rotated left the number of bits specified 
by operand SH. A mask is generated having 1 bits from bit MB 
through bit ME and 0 bits elsewhere. The rotated data is ANDed 
with the generated mask and the result is placed into rA. 


Description rlwinm can be used to extract, rotate, shift, and clear bit fields 
using the methods shown below: 


11 To extract an n field, that starts at bit position b in rs, 
right-justified into rA (clearing the remaining 32 —n bits 
of rA), set SH = b +n, MB = 32 —n, and ME = 31. 

1 To extract an n field, that starts at bit position b in rS, left- 
justified into rA (clearing the remaining 32 — n bits 
of rA), set SH = b, MB =0, and ME=n-1. 

1 To rotate the contents of a register left (or right) by n bits, 
set SH = n (82 —n), MB = 0, and ME = 31. 

1 To shift the contents of a register right by n bits, by setting 
SH = 32—n, MB =n, and ME = 31. It can be used to clear 
the high-order b bits of a register and then shift the result 
left by n bits by setting SH =n, MB=b-—nand 
ME = 31 —n. 

() To clear the low-order n bits of a register, by setting 
SH = 0, MB = 0, and ME = 31 —n. 
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MPC823 Instruction Set—riwinm 


Other registers altered: 


(1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO(if Re = 1) 
Simplified mnemonics: 


rA 
A 


wine 

. twin 

«S, twin 

prawn | equivalentio[riwinm [rAS,82— 70,31 

. twine | 
wine 

twine | 

Fiwinwn 






rA,rS,b,0,n — 1 


rA,rS,n(n< 32) rA,rS,32 —1n,n,31 
Asn (082) 
Asn (082) 
rA,rs,b,n (ns b< 32) rA,rs,n,b—n,31—n 
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MPC823 Instruction Set—rlwnm 


rlwnm 


Assembler Syntax rlwnm rA,rS,rB,MB,ME (Rc = 0) 
rlwnm. rA,rS,rB,MB,ME (Rc = 1) 
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Definition Rotate Left Word then AND with Mask 


Operation _ n< rB[27-31] 
r< ROTL(FS, n) 
m <— MASK(MB, ME) 
rA<r&m 


Description The contents of rS are rotated left the number of bits specified 
by the low-order five bits of rB. A mask is generated having 1 bits 
from bit MB through bit ME and 0 bits elsewhere. The rotated 
data is ANDed with the generated mask and the result is placed 
into rA. 


rlwnm can be used to extract and rotate bit fields using the 
methods shown as follows: 
11 To extract an n field, that starts at variable bit position b 
in rS, right-justified into rA (clearing the remaining 
32 —n bits of rA), by setting the low-order five bits of rB 
tob +n, MB = 32—-n, and ME = 31. 
1 To extract ann field, that starts at variable bit position b 
in rS, left-justified into rA (clearing the remaining 32 —n 
bits of rA), by setting the low-order five bits of rB to b, 
MB = 0, and ME =n —-1. 
1 To rotate the contents of a register left (or right) by n bits, 
by setting the low-order five bits of rB to n (32 —n), 
MB = 0, and ME = 31. 


B-122 . MPC823 USER’S MANUAL MOTOROLA 


MOTOROLA 


MPC823 Instruction Set—rlwnm 


Other registers altered: 


[1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
Simplified mnemonics: 


row [Arr] oqvaontio [rim [ArSr6 037 
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MPC823 Instruction Set—sc | 


sc 


Assembler Syntax SC 





Definition — system Cail 


Description The sc instruction calls the operating system to perform a 
service. When control is returned to the program that executed 
the system call, the content of the registers depends on the 
register conventions used by the program providing the system 
service. 


The effective address of the instruction following the sc 
instruction is placed into SRRO. Bits 0, 5-9, and 16-31 of the 
MSR are placed into the corresponding bits of SRR1, and bits 1- 
4 and 10-15 of SRR1 are set to undefined values. An sc 
exception is generated. The exception alters the MSR. The 
exception causes the next instruction to be fetched from offset 
OxCO00 from the base real address indicated by the new setting 


ACA TAs 


of MSAXIP}. 

Other registers altered: 
[1 Dependent on the system service 
1) SRRO 


1) SRR1 
11 MSR 










POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL; FORM 
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MPC823 Instruction Set—slw 


Siw 


Assembler Syntax slw rA,rS,rB (Re = 0) 
slw. rA,rs,rB (Re = 1) 
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Definition Shift Left Word 


Operation n< rB[27-31] 
rA — ROTL(rS, n) 


Description lf bit 26 of rB = 0, the contents of rS are shifted left the number 
of bits specified by rB[27—31]. Bits shifted out of position O are 
lost. Zeros are supplied to the vacated positions on the right. The 
32-bit result is placed into rA. If bit 26 of rB = 1, 32 zeros are 
placed into rA. 


Other registers altered: 


Li Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
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MPC823 Instruction Set—sraw 


sfaw 


© | 


Assembler Syntax sraw rA,rS,rB (Rc = 0) 
sraw. rA,rS,rB (Re = 1) 
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Definition shift Right Algebraic Word 


Operation n< rBl[27-31] 
rA < ROTL(rS, n) 


Description If rB[26] = 0,then the contents of rS are shifted right the number 
of bits specified by rB[27—31]. Bits shifted out of position 31 are 
lost. The result is padded on the left with sign bits before being 
placed into rA. If rB[26] = 1, then rA is filled with 32 sign bits (bit 
0) from rS. CRO is set based on the value written into rA. 
XER|[CA] is set if rS contains a negative number and any 1 bits 
are shifted out of position 31; otherwise XER[CA] is cleared. A 
shift amount of zero causes XER[CA] to be cleared. 


The sraw insiruction, foliowed by aaaze, can by useat 
quickly by 2”. The setting of the XER[CA] bit, by sraw, is 
independent of mode. 
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Other registers altered: 
[1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO(if Re = 1) 
L) XER: 
Affected: CA 
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MPC823 Instruction Set—srawi 


srawl 


Assembler Syntax srawi rA,rS,SH (Re = 0) 
srawi. rA,rS,SH (Re = 1) 
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Definition Shift Right Algebraic Word Immediate 


Operation n< SH 
r< ROTL(rS, 32 — n) 


Description The contents of rS are shifted right the number of bits specified 
by operand SH. Bits shifted out of position 31 are lost. The 
shifted value is sign-extended before being placed in rA. The 
32-bit result is placed into rA. XER[CA] is set if rS contains a 
negative number and any 1 bits are shifted out of position 31; 
otherwise XER[CA] is cleared. A shift amount of zero causes 
XER[CA] to be cleared. 


The srawi instruction, followed by addze, can be used to divide 
quickly by 2”. The setting of the CA bit, by srawi, is independent 
of mode. 


Other registers altered: 
Ly Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
LY XER: 
Affected: CA 
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MPC823 Instruction Set—srw 


Srw 


Assembler Syntax srw rA,rS,rB (Re = 0) 
srw. rA,rS,rB (Re = 1) 





Definition shift Right Word 


Operation n< rBl27-31] 
r< ROTL(rS, 32 —n) 


Description The contents of rS are shifted right the number of bits specified 
by the low-order six bits of rB. Bits shifted out of position 31 are 
lost. Zeros are supplied to the vacated positions on the left. The 
result is placed into rA. 


Other registers altered: 


L1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
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MPC823 Instruction Set—stb 


stb 


Assembler Syntax stb rS,d(rA) 
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Definition Store Byte 


Operation ifrA=Othenb<0O 
else b< (rA) 
EA «+ b+ EXTS(d) 
MEM(EA, 1) < rS[24-31] 


Description EA is the sum (rAl0) + d. The contents of the low-order eight bits 
| of rS are stored into the byte in memory addressed by EA. 


Other registers altered: 
Li None 
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-MPC823 Instruction Set—stbu 


stbu 


Assembler Syntax stbu rS,d(rA) 





Definition Store Byte with Update 
Operation EA < (rA) + EXTS(qd) 
MEM(EA, 1) < rS[24-31] 
rA< EA 
Description EA is the sum (rA) + d. The contents of the low-order eight bits 


of rS are stored into the byte in memory addressed by EA. EA is 
placed into rA. If rA = 0, the instruction form is invalid. 


Other registers altered: 
Li None 
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stbux 


Assembler Syntax 


MPC823 Instruction Set—stbux 





stbux rS,rA,rB 





Definition 


Operation 


Description 


MOTOROLA 


Store Byte with Update Indexed 


EA < (rA) + (rB) 
MEM(EA, 1) <— rS[24-31] 
rA<EA 


EA is the sum (rA) + (rB). The contents of the low-order eight bits 
of rS are stored into the byte in memory addressed by EA. EA is 
placed into rA. If rA = 0, the instruction form is invalid. 


Other registers altered: 
Li None 
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MPC823 Instruction Set—stbx 


stbx 





Assembler Syntax stbx rS,rA,rB 
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Definition Store Byte Indexed 
Operation ifrA=0thenb<0O 
else b<¢< (rA) 
EA <b + (rB) 


MEM(EA, 1) < rS[24-31] 


Description EA is the sum (rAl0) + (rB). The contents of the low-order eight 
bits of rS are stored into the byte in memory addressed by EA. 


Other registers altered: 
Li None 
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MPC823 Instruction Set—sth 


sth 


Assembler Syntax sth rS,d(rA) 
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Definition Store Half Word 


Operation ifrA=Othenb<0O 
else b< (rA) 
EA < b+ EXTS(d) 
MEM(EA, 2) < rS[16-31] 


Description EA is the sum (rAlO) + d. The contents of the low-order 16 bits 
of rS are stored into the half word in memory addressed by EA. 


Other registers altered: 
Li None 
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MPC823 Instruction Set—sthbrx 


sthbrx 


Assembler Syntax 


Definition 


Operation 


Description 
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sthbrx rS,rA,rB 





Store Half Word Byte-Reverse Indexed 


ifrA=0Othenb<0O 

else b<(rA 

EA < b + (rB) 

MEM(EA, 2) < rS[24-31] Il rS[16-23] 


EA is the sum (rAlO) + (rB). The contents of the low-order eight 
bits of rS are stored into bits O—7 of the half word in memory 
addressed by EA. The contents of the subsequent low-order 
eight bits of rS are stored into bits 8—15 of the half word in 
memory addressed by EA. 


Other registers altered: 
Li None 
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MPC823 Instruction Set—sthu 


sthu 


Assembler Syntax sthu rS,d(rA) 





Definition Store Half Word with Update 
Operation EA < (rA) + EXTS(d) 
MEM(EA, 2) < rS[16-31] 
rA< EA 
Description EA is the sum (rA) + d. The contents of the low-order 16 bits of 


rS are stored into the half word in memory addressed by EA. EA 
is placed into rA. If rA = 0, the instruction form is invalid. 


Other registers altered: 
Li None 
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MPC823 Instruction Set—sthux 


sthux 





Assembler Syntax sthux rS,rA,rB 
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Definition Store Half Word with Update Indexed 
Operation EA < (rA) + (rB) 
MEM(EA, 2) < rS/[16-31] 
rA< EA 
Description EA is the sum (rA) + (rB). The contents of the low-order 16 bits 


of rS are stored into the half word in memory addressed by EA. 
EA is placed into rA. If rA = 0, the instruction form is invalid. 


Other registers altered: 
LI None 
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MPC823 Instruction Set—sthx 


sthx 


Assembler Syntax sthx rs,rA,rB 
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Definition Store Half Word Indexed 
Operation ifrA =O thenb< 0 

else b< (rA) 

EA <b + (rB) 


MEM(EA, 2) < rS[16-31] 


Description EA is the sum (rAl0) + (rB). The contents of the low-order 16 bits 
of rS are stored into the half word in memory addressed by EA. 


Other registers altered: 
Li None 
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stmw 


Assembler Syntax stmw rS,d(rA) 
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Definition Store Multiple Word 
Operation ifrA=0thenb< 0 
else b < (rA) 
EA < b + EXTS(d) 
rers 


do while r < 31 
*“MEM(EA, 4) + GPR(r) 

rer+1 

EA<+EA+4 


Description EA is the sum (rAl0) + d. n= (32 —rS). n consecutive words 
| starting at EA are stored from the GPRs rS through r31. For 

example, if rS = 30, 2 words are stored. EA must be a multiple 
of four. If it is not, either the system alignment exception handler 
is invoked or the results are DouNndedly uNnGefined. 
Note that this instruction is likely to have a greater latency and 
take longer to execute, perhaps much longer, than a sequence 
of individual load or store instructions that produce the same 
results. 


Other registers altered: 
Li None 








POWERPC ARCHITECTURE SUPERVISOR 


OPTIONAL 
LEVEL LEVEL 


- | ae ae — en ee 









—B-138 _ MPC823 USER’S MANUAL ~ MOTOROLA 


MPC823 Instruction Set—stswi 


stswi 


Assembler Syntax stswi rs ,rA,NB 
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Definition Store String Word Immediate 


Operation if rA = 0 then EA< 0 
else EA < (rA) 
if NB = 0 then ne 32 


else n< NB 
re rS—1 
ic 32 


do while n> 0 

if i = 32 then r<r+1 (mod 32) 
MEM(EA, 1) — GPR(r)[i-i + 7] 
ic i1+8 

if i = 64 theni< 32 

EA <— EA + 1 

n&n-1 


Description — EA is (rAl0). Let n= NB if NB #0, n= 32 if NB=0; nis the 
: number of bytes to store. Let nr= CEIL(n + 4); nris the number 
_ of registers to supply data. nconsecutive bytes starting at EA are 
stored from GPRs rS through rS + nr— 1. Bytes are stored left to 
right from each register. The sequence of registers wraps 
around through r0 if required. Under certain conditions (like 
segment boundary crossing), the data alignment exception 
handler may be invoked. In some implementations, this 
instruction Is likely to have a greater latency and take longer to 
execute than a sequence of individual load or store instructions 
that produce the same results. 


POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
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stswx 
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Assembler Syntax stswx rS,rA,rB 
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Definition Store String Word Indexed 


Operation ifrA=Othenb<0 
else b < (rA) 
EA <— b + (rB) 
n< XER[25-31] 
rers—1 
ic 32 
do while n> 0 7 
if i = 32 then r<— r+ 1 (mod 32) 
MEM(EA, 1) — GPR(n)[i-i + 7] 
ic i+8 | 
if i = 64 then i<« 32 
EA< EA+1 
nen-1 


Description. EA is the sum (rAl0) + (rB). Let n= XER[25—-31]; nis the number 
of bytes to store. Let nr= CEIL(n + 4); nris the number of 
registers to supply data. n consecutive bytes starting at EA are 
stored from GPRs rS through rS + nr— 1. Bytes are stored left to 
right from each register. The sequence of registers wraps 
around through r0 if required. If n= 0, no bytes are stored. Under 
certain conditions (for example, segment boundary crossing) the 
data alignment exception handler may be invoked. 


Note that, in some implementations, this instruction is likely to 
have a greater latency and take longer to execute, perhaps 
much longer, than a sequence of individual load or store 
instructions that produce the same results. 
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MPC823 Instruction Set—stw 


STW 


Assembler Syntax stw rS,d(rA) 
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Definition Store Word 


Operation ifrA=Othenb<0O 
else b< (rA) 
EA «b+ EXTS(d) 
~MEM(EA, 4) <— rS 


Description EA is the sum (rAl0) + d. The contents of rS are stored into the 
word in memory addressed by EA. 


Other registers altered: 
LJ None- 
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MPC823 Instruction Set—stwbrx 


twbrx 


Assembler Syntax 


Definition 


Operation 


Description 
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stwbrx 1S,rA,rB 
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Store Word Byte-Reverse Indexed 


ifrA=0thenb<0O 

else b¢ (rA) 

EA < b + (rB) 

MEM(EA, 4) <— rS[24-31] Il rS[16-23] |] rS[8-15] || rS[0-7] 


EA is the sum (rAl0) + (rB). The contents of the low-order eight 
bits of rS are stored into bits 0-7 of the word in memory 
addressed by EA. The contents of the subsequent eight low- 
order bits of rS are stored into bits 8—15 of the word in memory 
addressed by EA. The contents of the subsequent eight low- 
order bits of rS are stored into bits 16-23 of the word in memory 
addressed by EA. The contents of the subsequent eight low- 
order bits of rS are stored into bits 24—31 of the word in memory 
addressed by EA. 


Other registers altered: 
Li None 
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STWCX. 


Assembler Syntax 





Definition 


Operation 


Description 


MOTOROLA 


MPC823 Instruction Set—stwex. 


StWcx. rS,rA,rB 


Store Word Conditional Indexed 


if rA =0 then b <— 0 

else b < (rA) 

EA < b + (rB) 

if RESERVE then 

if RESERVE_ADDR = physical_addr(EA) 
MEM(EA, 4) <— rS 

CRO < 0b00 II Ob1 || XER[SO] 
else 

u < undefined 1-bit value 

if u then MEM(EA, 4) <— rS 
CRO < 0b00 I! u Il XER[SO}] 
RESERVE < 0 

else 

CRO < Ob00 |! ObO II XER[SO] 


EA is the sum (rAl0) + (rB). If the reserved bit is set, the stwex. 
instruction stores rS to effective address (rA + rB), clears the 
reserved bit, and sets CRO[EQ]. If the reserved bit is not set, the 
stwex. instruction does not do a store; it leaves the reserved bit 
cleared and clears CRO[EQ]. Software must look at CRO[EQ] to 
see if the stwex. was successful. 


The reserved bit is set by the lwarx instruction. The reserved bit 
is cleared by any stwex. instruction to any address, and also by 
snooping logic if it detects that another processor does any kind 
of store to the block indicated in the reservation buffer when 
reserved is set. 


If a reservation exists, and the memory address specified by the 
stwcex. instruction is the same as that specified by the load and 
reserve instruction that established the reservation, the contents 
of rS are stored into the word in memory addressed by EA and 
the reservation is cleared. 
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MPC823 Instruction Set—stwcx. 


lf a reservation exists, but the memory address specified by the 
stwex. instruction is not the same as that specified by the load 
and reserve instruction that established the reservation, the 
reservation is cleared, and it is undefined whether the contents 
of rS are stored into the word in memory addressed by EA. 


ay 


If no reservation exists, the instruction completes without altering 
memory. 
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The CRO field is set to reflect whether the store operation was 
performed as follows. 





CRO[LT GT EQ SO] = 0b00 || store_performed | | 
XER[SO] 


EA must be a multiple of four. If it is not, either the system 
alignment exception handler is invoked or the results are 
boundedly undefined. 


The granularity with which reservations are managed is 
implementation-dependent. Therefore, the memory to be 
accessed by the load and reserve and store conditional 
instructions should be allocated by a system library program. 


Other registers altered: 
[1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO 
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Definition store Word with Update 
Operation EA < (rA) + EXTS(d) 
MEM(EA, 4) <— rS 
rA< EA 
Description EA is the sum (rA) + d. The contents of rS are stored into the 


word in memory addressed by EA. EA is placed into rA. If rA = 
O, the instruction form is invalid. 


Other registers altered: 
Li None 
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MPC823 Instruction Set—stwux 


stwux 





Assembler Syntax stwux rs, rA,rB 





Definition Store Word with Update Indexed 
Operation EA < (rA) + (rB) 
MEM(EA, 4) < rS 
rA<EA 
Description EA is the sum (rA) + (rB). The contents of rS are stored into the 


word in memory addressed by EA. EA is placed into rA. If rA = 
0, the instruction form is invalid. 


Other registers altered: 
Ll None 
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MPC823 Instruction Set—stwx 


StWwxX 


Assembler Syntax stwx rS,rA,rB 
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Definition Store Word Indexed 
Operation ifrA=Othenb<0O 
else b < (rA) 
EA < b + (rB) 


MEM(EA, 4) — rS 


Description EA is the sum (rAl0) + (rB). The contents of rS are is stored into 
the word in memory addressed by EA. 


Other registers altered: 
Li None 
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& Assembler Syntax subf rD,rA,rB (OE = 0 Re=0 
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5 , subfo rD,rA,rB (OE = 1 Rc =0 
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Definition Subtract From 
Operation rD — - (rA) + (rB) + 1 
Description The sum — (rA) + (rB) + 1 is placed into rD. The subf instruction 


is preferred for subtraction because it sets few status bits. 


Other registers altered: 


Li Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1 


(J XER: 
Affected: SO, OV (if OE = 1) 


Simplified mnemonics: 


equivalent to rD,rB,rA 
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subfco rD,rA,rB (OE = 1 Re = 0) = 
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Definition Subtract from Carrying 
Operation rD — = (rA) + (rB) + 1 
Description The sum - (rA) + (rB) + 1 is placed into rD. 


Other registers altered: 
LI Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
The CRO field may not reflect the “true” (infinitely precise) 
result if overflow occurs (see XER below). 


L) XER: 
Affected: CA 


Affected: SO, OV (if OE = 1) 
Simplified mnemonics: 


fsubc rD,rA,rB equivalent to ssubfc — rD,rB,rA 












POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 


SO 


MOTOROLA MPC823 USER’S MANUAL B-149 


MPC823 Instruction Set—subfe 





subfe 
& Assembler Syntax subfe  —_—s rD, rA,rB (OE = O Rc = 0) 
= subfe. rD,rA,rB (OE = 0 Rc = 1) 
S -subfeo —srD, rA,rB (OE = 1 Rc = 0) 
on subfeo. | rD,rA,rB (OE = 1 Re = 1) 





Definition Subtract from Extended 
Operation rD < - (rA) + (rB) + XER[CA] 
Description és The sum - (rA) + (rB) + XER[CA] is placed into rD. 


Other registers altered: 
_ (4 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Rc = 1) 
eee v ~~ ‘The CRO field may not reflect the “true” (infinitely precise 
ore eee 4 result if overflow occurs (see XER below). 


(} XER: 
Affected: CA 


Affected: SO, OV (if OE = 1 
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Assembler Syntax subfic rD,rA,SIMM 
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Definition subtract from Immediate Carrying 
Operation rD — 7 (rA) + EXTS(SIMM) + 1 
Description The sum - (rA) + EXTS(SIMM) + 1 is placed into rD. 


Other registers altered: 


LJ} XER: 
Affected: CA 





POWERPC ARCHITECTURE SUPERVISOR | OPTIONAL 
LEVEL LEVEL 


ee ee ee Ce 





MOTOROLA MPC823 USER’S MANUAL B-151 


a 
io) 
—_ 
a8) 
Cc 
= 
oO 
= 
w 
m 
a 





MPC823 Instruction Set—subfme 


subfme 


Assembler Syntax 


Definition 
Operation 


Description 
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subfme rD,rA (OE 
subfme. rD,rA (OE 


subfmeo rD,rA (OE =1 Re 
subfmeo. rD,rA (OE 
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Subtract from Minus One Extended 
rD — - (rA) + XER[CA] — 1 
The sum - (rA) + XER[CA] + (32)1 is placed into rD. 


Other registers altered: 


1 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO(if Re = 1 
The CRO field may not reflect the “true” (infinitely precise 
result if overflow occurs (see XER below). 


L) XER: 
Affected: CA 


Affected: SO, OV (if OE = 1 
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subfze 


Assembler Syntax 





Definition 
Operation 


Description 
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MPC823 Instruction Set—subfze 


subfze rD,rA (OE =0Rc=0) 
subfze. rD,rA (OE =0 Rc=1) 
subfzeo rD,rA (OE =1 Rc=0) 
subfzeo. rD,rA (OE =1 Re= 1) 


Subtract from Zero Extended 
rD — - (rA) + XER[CA] 
The sum - (rA) + XER[CA] is placed into rD. 


Other registers altered: 
LI Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
The CRO field may not reflect the “true” (infinitely precise) 
result if overflow occurs (see XER below). 
 XER: | 
Affected: CA 
Affected: SO, OV (if OE = 1) 
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MPC823 Instruction Set—sync 


sync 


Assembler Syntax sync 








Definition 7 synchronize 


Description The sync instruction provides an ordering function for the effects 
of all instructions executed by a given processor. Executing a 
sync instruction ensures that all instructions preceding the syne 
instruction appear to have completed before the sync instruction 
completes, and that no subsequent instructions are initiated by 

_ the processor until after the sync instruction completes. When 
the sync instruction completes, all external accesses caused by 
instructions preceding the sync instruction will have been 
performed with respect to all other mechanisms that access 
memory. “3 oe - S 7 


Multiprocessor implementations also send a sync address-only 
broadcast that is useful in some designs. For example, if a 
design nas an exiernai buffer that reoraers ioads and stores for 
better bus efficiency, the sync broadcast signals to that buffer 
that previous loads/stores must be completed before any 
following loads/stores. The sync instruction can be used to 
ensure that the results of all stores into a data structure, caused 
by store instructions executed in a “critical section” of a program, 
are seen by other processors before the data structure is seen 
as unlocked. The functions performed by the sync instruction 
will normally take a significant amount of time to complete, so 
indiscriminate use of this instruction may adversely affect 
performance. In addition, the time required to execute syne may 
vary from one execution to another. The eieio instruction may be 
more appropriate than sync for many cases. 
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MPC823 Instruction Set—tlibia 


tibia 


Assembler Syntax tlbia 
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Definition _ Translation Lookaside Buffer Invalidate All 
Operation All TLB entries < invalid 
Description The entire translation lookaside buffer (TLB) is invalidated (that 


is, all entries are removed). The TLB is invalidated regardless of 
the settings of MSR[IR] and MSR[DR]. The invalidation is done 
without reference to the SLB, segment table, or segment 
registers. This instruction does not cause the entries to be 
invalidated in other processors. This is a supervisor-level 
instructon. | 


Other registers altered: 
Li None 
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MPC823 Instruction Set—tlbie 


tibie 


Assembler Syntax tlbie rB 


= 
—D-. 
— 
a 
Cc 
© 
pa 
2) 
= 
mo?) 
7m 
— 





Definition | Translation Lookaside Buffer Invalidate Entry 


Operation VPS < rB[4-19] 
Identify TLB entries corresponding to VPS 
Each such TLB entry < invalid 


Description EA is the contents of rB. If the translation lookaside buffer (TLB) 
: | contains an entry corresponding to EA, that entry is made invalid 
(that is, removed from the TLB). 


Multiprocessing implementations (for example, the 601, and 
604) send a tlbie address-only broadcast over the address bus 
to tell other processors to invalidate the same TLB entry in their 
TLBs. 


The TLB search is done regardless of the settings of MSRIIR] 
and MSR[DR]. The search is done based on a portion of the 
logical page number within a segment, without reference to the 
segment registers. All entries matching the search criteria are 


invalidated. 


Block address translation for EA, if any, is ignored. This is a 
supervisor-level instruction. 


Other registers altered: 
Li None 
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MPC823 Instruction Set—tlbsync 


tlbsync 


Assembler Syntax tlbsync 
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Definition TLB Synchronize 


Description If an implementation sends a broadcast for tlbie then it will also 
send a broadcast for tlbsync. Executing a tlbsync instruction 
ensures that all tlbie instructions previously executed by the 
processor executing the tlbsync instruction have completed on 
all other processors. The operation performed by this instruction 
is treated as a caching-inhibited and guarded data access with 
respect to the ordering done by eleio. This instruction is 
supervisor-level. 


Other registers altered: 
Li None 


POWERPC ARCHITECTURE | SUPERVISOR | OPTIONAL i 
LEVEL 





MOTOROLA MPC823 USER’S MANUAL B-157 


= 
” 
—+ 
ms 
Cc 
© 
= 
2) 
= 
WM 
uy 
—_ 





MPC823 Instruction Set—tw 


tw 


SASNSS 


Definition 


Operation © 


Description 


B-158 


Se 
REN 
: 
ec 
SEER” Gao Sahat Sees 
BREESE Eo RN se Te 
=. 
Oe 8 


tw TO,rA,rB 


a ene Jasnson abapenbbisnpmiacnees 
Say 
oe SS See ES 

SENSE A SS ae a SE 
x = 
BS 8 SES 





Trap Word 


ae EXTS(KA) 


b — EXTS(rB) 

if (a <b) & TO[O] then TRAP 
if (a > b) & TO[1] then TRAP 
if (a = b) & TO[2] then TRAP 
if (a <U b) & TO[3] then TRAP 
if (a >U b) & TO[4] then TRAP 


om 


The contents of rA are compared with the contents of rB. If any 
bit in the TO field is set and its corresponding condition is met by 
the result of the comparison, then the system trap handler is 
invoked. 


Othe 


Li None 
Simplified mnemonics: 


equivalent to 
rA,rB equivalent to 
mie equivalent to 


“5 
“x 
(D 
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MPC823 Instruction Set—twi 


Assembler Syntax twi TO,rA,SIMM 





Definition Trap Word Immediate 


Operation a <— EXTS(rA) 
if (a < EXTS(SIMM)) & TO[O] then TRAP 
if (a > EXTS(SIMM)) & TO[1] then TRAP 
if (a = EXTS(SIMM)) & TO[2] then TRAP 
if (a <U EXTS(SIMM)) & TO[3] then TRAP 
if (a >U EXTS(SIMM)) & TO[4] then TRAP 


Description The contents of rA are compared with the sign-extended value 
of the SIMM field. If any bit in the TO field is set and its 
corresponding condition is met by the result of the comparison, 
then the system trap handler is invoked. 


Other registers altered: 
Li None 


Simplified mnemonics: 


twoti rA,value equivalent to 
jtwilei rA,value equivalent to 














8,rA,value 





6,rA,value 
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MPC823 Instruction Set—xor 


XOF 





Assembler Syntax xor rA,rs,rB (Re 
xor. rA,rS,rB (Rc 
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Definition XOR 
Operation tA < (rS) @ (rB) 
Description | The contents of rS is XORed with the contents of rB and the 


result is placed into rA. 


Other registers altered: 


| ~ {4 Condition Register (CRO field): 
Affected: LT, GT, EQ, SO (if Re = 1) 
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MPC823 Instruction Set—xori 


Xxorl 


Assembler Syntax xori rA,rS,UIMM 
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Definition XOR Immediate 
Operation rA <— (rS) © ((16)0 Il UIMM) 
Description The contents of rS are XORed with 0x0000 || UIMM and the 


result is placed into rA. 


Other registers altered: 
Li None 
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MPC823 Instruction Set—xoris 


xoris 





Assembler Syntax xoris rA,rS,UIMM ; 
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Definition XOR Immediate Shifted 
Operation rA <— (rS) ® (UIMM II (16)0 
Description The contents of rS are XORed with UIMM || 0x0000 and the 


result is placed into rA. 


Other registers altered: 
Li None 
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INDEX 


A 


access, restricting, 15-5 
acronyms (defined), 24-1 
address bus, 13-32 
address field, 16-266 
address multiplexing, 15-60 
address translation, 11-2 
ALE_B, 2-7 
algorithm, RISC timer table, 16-27 
APG (definition), 11-4 
AppleTalk (LocalTalk), 16-258 
applications, 1-12 
arbitration, 13-27 
architecture 

memory controller, 15-4 


MPC823, 1-7 
PowerPC, 7-1 
AS, 2-6 


ASID (definition), 11-2 

ASYNC HDLC (SCC2) mode, 16-262 
asynchronous bus masters, 15-66, 15-68 
asynchronous mode, 16-197 

ATO, 2-8 

AT1, 2-7 

AT2, 2-7 

AT3, 2-8 

atomic transaction, 13-16 

atomic update primitives, 7-4 
autobaud operation, 16-153 
autobuffer, 16-92 


back trace, 20-6 
BAR, 6-17, 20-44 
base registers, 15-9 
battery preservation, 5-24 
baud rate generator clock frequency, 5-20 
baud rate generators, 16-151 
block diagram, 16-151 
configuration register (BRGCx), 16-154 
features, 16-151 
memory map, 3-8 
UART examples, 16-156 
baud rates, typical, 16-156 


BB, 2-4, 13-7, 13-29 
BD (definition), 16-172 
BDIP, 2-2, 13-5, 13-36 
BG, 2-4, 13-7, 13-29 
Bl, 2-3, 13-6, 13-36 
big-endian SDMA, 16-85 
bit assignments 
control registers, 6-20 
bit-stuffing (definition), 16-227 
BLANK, 2-11 
block diagrams 
baud rate generators, 16-151 
clocks, 5-11 
communication processor module, 16-3 
core, 6-3 
data cache, 10-2 
DPLL receive, 16-188 
DPLL transmit, 16-188 
l?C controller, 16-446 
IEEE 1149.1 test access port, 21-2 
instruction cache, 9-3 
LCD controller, 18-6 
memory controller, 15-3 
memory periodic timer request, 15-43 
MPC823, 1-8 
parallel I/O port PA14, 16-473 
parallel I/O port PA15, 16-472 
periodic interrupt timer, 12-22 
real-time clock, 12-17 
RISC microcontroller, 16-5 
serial communication controller, 16-158 
serial interface, 16-114 
serial management controllers, 16-372 
serial peripheral interface, 16-424 
software watchdog timer, 12-27 
SPLL, 5-12 
timers, 16-76 
video controller, 19-3 
boot ROM, locating, 15-38 
boundary scan bit definitions, 21-7 
boundary scan register, 21-4 
BR, 2-4, 13-7, 13-28 
branch folding, 6-5 
branch instructions, predicted and 
mispredicted, 6-6 | 
branch prediction policy (table), 6-6 
branch reservation station, 6-6 
breakpoints, 20-9 
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index 


breaks, 16-205 
sending, 16-206 
BRG (definition), 16-151 
BRGCLK divisor, defining, 15-28 
BRGCLK, 5-19 
BRGCx, 16-154 
BRGO1, 2-8, 2-9 
BRGO2, 2-9 
BRGO3, 2-9 
BRGOUT2, 2-9 
BS, 15-56 
BS_BO, 2-5 
BS_B1, 2-5 
BS_B2, 2-5 
BS_B3, 2-5 
buffer chaining, 16-92 
buffer descriptor ring, USB, 16-367 
buffer descriptors 
l2C controller 
receive, 16-459 
transmit, 16-461 
IDMA, 16-97 
SCC2 in ASYNC HDLC mode 
receive, 16-273 
transmit, 16-275 
SCC2 in Ethernet mode 
receive, 16-332 
transmit, 16-335 
SCC2 in HDLC mode 
receive, 16-237 
transmit, 16-241 
SCC2 in Transparent mode 
receive, 16-303 
transmit, 16-305 
SCC2 in UART mode 
receive, 16-214 
transmit, 16-218 
SCC2, 16-172 
serial management controllers, 16-374 
serial peripheral interface 
receive, 16-437 
transmit, 16-439 
SMC in Transparent mode 
receive, 16-408 
transmit, 16-410 
SMC in UART mode | 
receive, 16-389 
transmit, 16-393 
universal serial bus 
receive, 16-358 
transmit, 16-361 
burst access, initiated by the MPC823, 13-44 
_ burst mechanism, 13-16 
burst show cycle, 13-33 
BURST, 2-2, 13-4, 13-32 
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bus arbitration and transfers, 16-86 
bus bandwidth utilization, minimizing, 10-11 
bus busy, 13-29 
bus cycle access, requesting, 15-8 
bus exceptions, 16-113 
bus grant, 13-29 
bus interface 
features, 13-1 
operation, 13-7 
address transfer phase signals, 13-31 
arbitration phase signals, 13-27 
basic transfers, 13-8 
burst mechanism, 13-16 
burst transfers, 13-16 
data transfer phase signals, 13-36 
exception control cycles, 13-41 
single beat transfers, 13-8 
storage reservation, 13-38 
termination signals, 13-36 
transfer alignment and packaging, 13-25 
signal descriptions, 13-4 
transfer signals, 13-2 
bus master support, 15-68 
bus master, becoming, 13-27 
bus monitor, 12-11 
bus request, 13-28 
bus signals (illustration), 13-3 
byte selects, enabling, 15-57 


C 


C/\ (definition), 16-145 
cache coherency, 9-14, 10-13 
cache hit, 9-1, 9-7 
cache inhibit, 11-4 
cache miss, 9-1, 9-8 
CAM (definition), 16-159 
cascaded mode, 16-78 
CASID (definition), 11-2 
CD2, 2-10 
CE1_B, 2-4 
CE2_B, 2-5 
channel reception 
SMC in GCI mode (C/I), 16-416 
SMC in GCI mode (monitor), 16-416 
channel transmission 
SMC in GCI mode (C/I), 16-416 
SMC in GCI mode (monitor), 16-416 
checkstop state, 7-9 
chip-select logic 
updating code and programming memory 
regions, 9-14 
CICR, 16-495 
CIMR, 16-498 
CIPR, 16-497 
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CISR, 16-499 
CIVR, 16-500 
CLK, 2-12 
CLK1, 2-8 
CLK2, 2-8 
CLK3, 2-9 
CLK4, 2-9 
CLKOUT, 2-6, 5-16, 5-19 
clock glitches, 16-191 
clock input to the prescaler, 16-152 
clock operation, 5-10 
clock skew, 13-7 
clock source and configuration options, 
determining, 5-22 
clock source and distribution (illustration), 5-2 
clock, of the video controller, 19-3 
clock, SPLL reference, 5-12 
clocks and power control, 5-1 
block diagram, 5-11 
configuration, 5-22 
features, 5-1 
internal clock signals, 5-16 
baud rate generator clock, 5-19 
general system clocks, 5-16 
LCD clocks, 5-21 
synchronization clocks, 5-20 
keys memory map, 3-4 
low-power divider, 5-14 
memory map, 3-4 
operation, 5-10 
oscillators and external clock input, 5-12 
system PLL, 5-12 
registers, 5-3 
timing, 15-45 
CMPA-D, 20-42 
CMPAx, 6-17 
CMPE-F, 20-43 
CMPG-H, 20-43 
coding, 16-190 
collisions, 16-259, 16-327 
color RAM, 18-11 
commands 
ARM IDMA, 16-12, 16-101 
CACHE DISABLE, 9-11 
CACHE ENABLE, 9-11 
CACHE LINE FLUSH, 10-13 
CLOSE RX BD, 16-12, 16-202, 16-234, 16-271, 
16-301, 16-324, 16-386, 16-405, 
16-431, 16-456 
COPYBACK, 10-13 
DATA CACHE DISABLE, 10-13 
DATA CACHE ENABLE, 10-13 
data cache, 10-13 
DEBUG PORT, 20-38 
DSP, 16-34 
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Index 


END DOWNLOAD PROCEDURE, 20-40 

ENDPOINT, 16-355 

ENTER HUNT MODE, 16-12, 16-201, 16-234, 
16-271, 16-301, 16-323, 16-386, 16-405 

FLG, 16-356 

GCI ABORT REQUEST, 16-12 

GCI TIMEOUT, 16-12 

GRACEFUL STOP TRANSMIT, 16-201, 
16-233, 16-270, 16-301, 16-323 

GRACEFUL STOP TX, 16-12 

12C controller, 16-456 

IDMA, 16-101 

INIT DSP CHAIN, 16-34 

INIT DSP, 16-12 

INIT IDMA, 16-12, 16-101 

INIT RX AND TX PARAMS, 16-12 

INIT RX PARAMETERS, 16-202, 16-234, 
16-271, 16-301, 16-324, 16-386, 16-405, 
16-431, 16-456 

INIT TX AND RX PARAMS, 16-420 

INIT TX PARAMETERS, 16-201, 16-233, 
16-270, 16-301, 16-323, 16-386, 16-405, 
16-431, 16-456 

INSTRUCTION CACHE BLOCK 
INVALIDATE, 9-9 

instruction cache, 9-8 

INVALIDATE ALL, 9-9, 10-13 

LOAD & LOCK, 9-10 

LOCK LINE, 10-13 

RESTART TRANSMIT, 16-201, 16-233, 
16-270, 16-301, 16-323, 16-386, 16-405 

RESTART TX, 16-12 

RISC microcontroller, 16-10, 16-12 

RST, 16-355 

RUN, 15-18, 15-41 

SCC2 in ASYNC HDLC mode, 16-270 

SCC2 in Ethernet mode, 16-323 

SCC2 in HDLC mode, 16-233 

SCC2 in Transparent mode, 16-300 

SCC2 in UART mode, 16-201 

serial peripheral interface, 16-431 

SET GROUP ADDRESS, 16-12, 16-324 

SET TIMER, 16-12, 16-24 

SMC in GCI mode, 16-420 

SMC in Transparent mode, 16-405 

SMC in UART mode, 16-386 

START DOWNLOAD PROCEDURE, 20-40 

START DSP CHAIN, 16-34 

START DSP, 16-12 

STOP IDMA, 16-12, 16-101 

STOP TRANSMIT, 16-201, 16-233, 16-270, 
16-300, 16-323, 16-386, 16-405 

STOP TX, 16-12 

TIMEOUT, 16-420 

TRANSMIT ABORT REQUEST, 16-420 
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commands (continued) 


universal serial bus, 16-355 
UNLOCK ALL, 9-11, 10-13 
UNLOCK LINE, 9-10, 10-13 
USB, 16-12 

USBCMD, 16-355 

WRITE, 15-78, 15-90 


communication processor module (CPM), 16-1 


baud rate generator clock, 5-19 
baud rate generators, 16-151 
autobaud operation, 16-153 
block diagram, 16-151 
configuration registers, 16-154 
features, 16-151 
UART baud rate examples, 16-156 
block diagram, 16-3 : 
commands 
CPM command register example, 16-14 
CPM interrupt controller, 16-487 
features, 16-489 
interrupt examples 
PC6, 16-500 
USB, 16-501 
interrupt vectors, 16-493 
masking interrupt sources, 16-492 
operation, 16-487 
programming, 16-495 
registers 
interrupt configuration, 16-495 
interrupt in-service, 16-499 
interrupt mask, 16-498 
interrupt pending, 16-497 
interrupt vector, 16-500 
source priorities, 16-489 
structure (illustration), 16-488 
digital signal processing, 16-28 
commands, 16-34 
DEMOD, 16-64 
execution times, 16-75 
features, 16-28 
FIR1, 16-41 
FIR2, 16-44 
FIR3, 16-48 
FIR5, 16-52 
FIR6G,. 16-56 
IIR, 16-59 
LMS1, 16-67 
LMS2, 16-69 
MOD, 16-62 
programming, 16-29 
WADD, 16-72 
features, 16-1 
C controller, 16-446 
block diagram, 16-446 
buffer descriptor ring, 16-457 
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commands, 16-456 
features, 16-447 
operation, 16-447 
parameter RAM memory map, 16-453 
programming, 16-458 
receive buffer descriptor, 16-459 
registers, 16-458 
transmission and reception, 16-448 
transmit buffer descriptor, 16-461 
IDMA emulation, 16-90 
buffer descriptors, 16-97 
commands, 16-101 
interface signals, 16-91 
operation, 16-91 
parameter RAM memory map, 16-93 
memory map, 3-8 
parallel I/O ports, 16-467 
features, 16-468 
port A 
configuration example, 16-472 
operation, 16-468 
pins, 16-469 
registers, 16-470 
port B : 
configuration example, 16-479 
operation, 16-474 
registers, 16-475 
port C 
pins, 16-479 
registers, 16-481 
. port D 
operation, 16-485 
registers, 16-486 
RISC microcontroller, 16-4 
block diagram, 16-5 
commands, 16-10, 16-12 
configuration register (RCCR), 16-8 
core interface, 16-6 
features, 16-5 
microcode development. support control 
register (RMDS), 16-7 
microcode, 16-7 
SDMA channels, 16-84 
bus arbitration and transfers, 16-86 
serial communication controller, 16-157 
AppleTalk mode 
features, 16-259 
programming examples, 16-262 
programming, 16-261 
ASYNC HDLC mode, 16-262 
commands, 16-270 
configuration, 16-269 
ry errors, 16-271 | 
parameter RAM memory map, 16-267 
_ programming, 16-272 
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communication processor module 
serial communication controller (continued) 


Transparent mode, 16-294 
commands, 16-300 
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receive buffer descriptors, 16-273 
registers, 16-272 
transmit buffer descriptor, 16-275 
block diagram, 16-158 
buffer descriptors, 16-172 
clock glitches, 16-191 
data synchronization register, 16-171 
digital phase-locked loop, 16-187 
disabling on-the-fly, 16-193 
DPLL and serial infra-red 
encoder/decoder, 16-192 
DPLL receive block diagram, 16-188 
DPLL transmit block diagram, 16-188 
Ethernet mode, 16-311 | 
commands, 16-323 
configuration, 16-322 
errors, 16-328 
features, 16-312 
operation, 16-312 
parameter RAM memory map, 16- 318 
programming example, 16-340 
receive buffer descriptor, 16-332 
registers, 16-329 
transmit buffer descriptor, 16-335 
event register (SCCE), 16-181 
features, 16-159 
general SCC mode registers, 16-160 
HDLC bus controller, 16-250 
features, 16-252 
HDLC mode, 16-227 
commands, 16-233 
errors, 16-234 
features, 16-228 
parameter RAM memory map, 16- 230 
programming, 16-232 
receive buffer descriptors, 16-237 
registers, 16-236 
transmit buffer descriptor, 16-241 
initialization, 16-182 
interrupts, 16-181 
IrDA mode, 16-280 
examples, 16-290 
high-speed, 16-283 
low-speed, 16-281 
middle-speed, 16-282 
registers, 16-287 7 
mask register (SCCM), 16-181 . 
parameter RAM memory map, 16-176 
protocol-specific mode register, 16-170 
features, 16-228 
status register (SCCS), 16-181 
timing control, 16-183 
transmit-on-demand register, 16- 171 


errors, 16-302 

examples, 16-310 

features, 16-295 

operation, 16-294 

parameter RAM memory map, 16-300 

receive buffer descriptors, 16-303 

registers, 16-302 

transmit buffer descriptors, 16-305 
UART mode, 16-195 

commands, 16-201 

errors, 16-208 

features, 16-196 

programming, 16-200 

receive buffer descriptors, 16-214 

registers, 16-211 

transmit buffer descriptors, 16-218 


serial interface with time-slot assigner, 16-113 


block diagram, 16-114 
configuration, 16-115 
connections, 16-118. 

features, 16-115 

general circuit interface, 16- 145 
IDL interface, 16-139 

NMSI configuration, 16-148 
RAM operation, 16-118 
registers, 16-126 


serial management controllers 


block diagram, 16-372 
buffer descriptor operation, 16-374 
disabling on-the-fly, 16-380 
features, 16-373 
GCI mode, 16-415 
commands, 16-420 
features, 16-415 | 
parameter RAM memory map, 16-417 
registers, 16-421 
general SMC mode register, 16-374 
operation, 16-372 | 
Transparent mode, 16- 399 
commands, 16-405 
errors, 16-406 
features, 16-399. 
interrupts, 16-415 . 
NMSI programming example, 16-413 
parameter RAM memory map, 16-405 
receive buffer descriptor, 16-408 
registers, 16-406 
transmit buffer descriptor, 16- 410. 
TSA programming pees 16-414 | 
UART mode, 16-382 
commands, 16-386 © 
errors, 16-387 
features, 16-383 
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communication processor module 
serial management controllers 
UART mode (continued) 
interrupts, 16-398 
parameter RAM memory map, 16-384 
programming example, 16-397 
programming, 16-385 
receive buffer descriptor, 16-389 
registers, 16-388 
transmit buffer descriptor, 16-393 
serial peripheral interface, 16-423 
block diagram, 16-424 
features, 16-424 
interrupts, 16-445 
master programming example, 16-443 
operation, 16-425 
parameter RAM memory map, 16-428 
programming, 16-433 
receive buffer descriptor, 16-437 
registers, 16-433 , 
slave programming example, 16-444 
transmission and reception, 16-426 
transmit buffer descriptor, 16-439 
synchronization clocks, 5-20 
timers 
block diagram, 16-76 
cascaded mode block diagram, 16-78 
examples, 16-83 
features, 16-76 
operation, 16-77 
universal serial bus, 16-342 
buffer descriptor ring, 16-366 
command register, 16-364 
commands, 16-355 
endpoint registers, 16-365 | 
errors, 16-356 
event register, 16-368. 
features, 16-343 _ 
initialization example, 16-369 
mask register, 16-369 
mode register, 16-357 
operation, 16-345 
parameter RAM memory map, 16-350 
receive buffer descriptor, 16-358 
slave address register, 16-363 
status register, 16-369 
transmission and reception, 16-347 
transmit buffer descriptor, 16-361 
communication, with peripherals, 16-6 
communication, with the core, 16-6 
comparing timer counts, 16-27 — 
condition register, 6- 22 
configuration 
clock, 5-22 
for PCMCIA, 17-1 
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general-purpose chip-select machine, 15-28 
HDLC bus controller, 16-251 
memory controller (illustration), 15-5 
NMSI, 16-148 
page mode DRAM, 15-77 
page mode extended data-out DRAM, 15-89 
port A example, 16-472 
port B example, 16-479 
power-on reset clock (table), 5- 13 
reset, 4-7 
SCC2 in ASYNC HDLC mode, 16-269 
SCC2 in Ethernet mode, 16-322 
system endian, 14-1 
system interface unit, 12-2 
TDM with dynamic frames, 16-120 - 
TDM with static frames, 16-119 
time-slot assigner, 16-115 
UPMA, 15-19" 
UPMB, 15-23 
connecting MPC823 to external peripheral, 15-32 
connecting the MPC823 to an SRAM device, 15-39 
connecting the MPC823 to memory device, 15-30 
connecting the MPC823 to static RAM 
memory, 15-39 . 
connecting UPM RAM array to DRAM, 15-77 
connections 
IrDA, 16-192 
SCC2 in AppleTalk mode, 16-260 
to the time-slot assigner, 16-118 
content-addressable memory, 16-159 
control byte, 16-258 
control field, 16-266 
control frames, 16-258 » 
copyback mode, 10-11 
core, 6-1 
basic instruction pipeline, 6-4 
basic structure, 6-2 
block diagram, 6-3 
features, 6-1 
instruction flow, 6-2 
register unit, 6-15 
control registers, 6-16 
sequencer unit, 6-4 
external interrupt, 6-13 
flow control, 6-5 
interrrupt ordering, 6-14 
interrupt processing, 6-11 
interrupts, 6-7 
issuing instructions, 6-6 
precise exception model, 6-8 
serialization, 6-12 
cost, reduction, 5-12 — 
COUNTA, 20-53 
COUNTB, 20-54 
CPCR, 16-10 
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CPM command register, 16-10 
CPM interrupt controller, 16-487 
configuration register (CICR), 16-495 
features, 16-489 
in-service register (CISR), 16-499 
interrupt mask register (CIMR), 16-498 
interrupt pending register (CIPR), 16-497 
interrupt structure (illustration), 16-488 
interrupt vector register (CIVR), 16-500 
interrupt vectors 
encoding, 16-494 
interrupts, 16-500 
masking interrupts, 16-492 
operation, 16-487 
PC6 example, 16-500 
programming, 16-495 
source priorities, 16-489 
highest priority interrupt, 16-490 
nested interrupts, 16-492 
USB and SCC2 relative priority, 16-490 
USB example, 16-501 
CPM, 16-1 
CR, 6-19, 6-22 
CS output configurations, 15- 30 
CS, 15-55 
CS2, 2-6 
CS3, 2-6 


CSMA/CD, 16-311 
CTS2, 2-10 
cycle types, 15-42 


D 


DAR, 6-16, 7-10 
data cache, 10-1 
block diagram, 10-2 | 
cache-inhibited accesses, 10-12 
coherency, 10-13 
commands 
CACHE LINE FLUSH, 10-13 
COPYBACK, 10-13 
DATA CACHE DISABLE, 10-13 
DATA CACHE ENABLE, 10-13 | 
INVALIDATE ALL, 10-13 
LOCK LINE, 10-13 
UNLOCK ALL, 10-13 
UNLOCK LINE, 10-13 
data path block diagram, 10-3 
debug support, 10-12 | 
features, 10-1 : 
freeze, 10-12 
how to enable and disable, 10-13 
implementation-specific operations, 10-4 
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index 


instructions, 10-3, 10-14 
operation, 10-10 
organization, 10-2 
programming, 10-3 
read, 10-10 
reading, 10-14 
special registers, 10-4 
write, 10-11 
data cache address register, 10-7 
data cache control and status register, 10-5 
data cache, how to flush and invalidate, 10-13 © 
data sampling, 15-64 
DC_ADR, 10-7 
DC_CSR, 10-5 
dcbf, 10-14, 11-48 
debi, 10-14, 11-48 
dcbst, 10-14, 11-48 
debt, 10-14 
dcbtst, 10-14 
dcbz, 10-14, 11-48 
debug mode 
entering, 20-26 
DEC, 12-13 3 
decoding data, with a DPLL, 16-190 
decrementer register, 12-13 
decrementer, 12-12 
DEMOD, 16-64 
applications, 16-67 
function descriptor, 16-65 — 
modulation table, sample data buffers, and 
AGC constants, 16-65 : 
parameter packet, 16-66 
DER, 6-17, 20-57 
development capabilities, 20-1 . | 
development system interface, 20-20 
debug mode support, 20-22 
development interface port shift 
register, 20-30 
development port, 20-29 
trap enable control register, 20- 31 
trap enable mode, 20-22 
features, 20-1 
program flow tracking, 20-2 
instruction fetch show a control, 20-8 
operation, 20-3 | | | 
compressing cancelled _ 
instructions, 20-8 
external hardware, 20-5 
internal hardware, 20-3 
programming, 20-41 | 
debug mode registers, 20-55 © 
development port data registers, 20-60 
development port registers, 20-42 
protecting the registers, 20-41 — 
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development capabilities (continued) 
software monitor debugger support 
freeze indication, 20-41 | 
watchpoints and breakpoints 
examples, 20-13 
internal, 20-9 
operation, 20-16 
development port, 20-29 
configuration, 4-7 
DFNH, 5-17 
DFNL, 5-17 
dialog, 16-259 
differences | 
between autobuffer and buffer chaining, 16-97 
HDLC and ASYNC HDLC, 16-279 
differential Manchester, 16-191 — | 
digital phase-locked loop, 16-187 
digital signal processing, 16-28 
disable timer mechanism, 15-44, 15-64 
disabling 
all modules, 16-193 
idle sequence function, 16-209 
part of SCC transmitter, 16-193 
part of SCC2 receiver, 16-194 
part of SMC receiver, 16-382 
part of SMC transmitter, 16-381 
SCC2 receiver, 16-194 
SCC2 transmitter, 16-193 
SCC2, 16-193 
SMC receiver, 16-381 
SMC transmitter, 16-381 
SMC, 16-380 
DMA 
PCMCIA, 17-8 © 
DMA controller 
memory map, 3-6 
DMA, video controller, 19-4 
DPO, 2-3 
DP1, 2-3 
DP2, 2-4 
DPS, 2-4 
DPDR, 6-17, 20- 60 
DPIR, 6-17 
DPIR/DPDR, 20-30 | 
DPLL (definition), 16-187 
DRAM bank, sharing access to, 15-72 
_ DRAM with RAS precharge time, 15-64 
DRAM, types, 15-77 | 
DREQ1, 2-10 
DREQ2, 2-10 
DREQx, about, 16-91" 
DSCK, 2-7, 2-12, 20-29 
DSDI, 2-12, 20-29 
DSDO, 2-8, 2-12, 20-29 
DSISR, 6-16, 7-10 
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DSP 
firmware, 16-29 
function descriptors, 16-31 
functionality, 16-28 
hardware, 16-29 
implementation, 16-37 
library, 16-40 
parameter RAM, 16-32 
programming example (core and CPM), 16-39 
programming example (core), 16-38 
software, 16-29 

DSR, 16-171 

dual-port RAM memory map, 3-11 


E 


echo mode (automatic), 16-169, 16-116. 
edge interrupt, 12-7 
edge sensitive IDMA, 16-91 . 
EDO (definition), 15-89 
EEST, 16-314 
eieio, 11-52 
electrical contention, avoiding, 13-37 
electrical information, 22-1 
DC, 22-4 
layout, 22-3 
power, 22-2 
ratings, 22-1 
thermal, 22-2 
emulation, IDMA, 16-90 
emulators, 20-1 
encoding data, with a DPLL, 16-190 
encoding, 16-266 
endian modes, 14-1 
big endian, 14-5 
little endian, 14-3 
operation, 14-2, 14-5 
PowerPC little-endian, 14-5 © 
errors 
abort sequence, 16-235, 16-271 
break sequence received, 16-272 
break sequence, 16-210, 16-387 
busy, 16-328, 16-356 | 
carrier sense lost during frame 
transmission, 16-328 
CD lost during character reception, 16-209 
CD lost during frame reception, 16-235, 16-271 
CD lost during message reception, 16-302 
control characters, 16-204 | 
CRC, 16-235, 16-272, 16-329, 16-356 
CTS lost during character transmission, 16-208 
CTS lost during frame transmission, 
16-234, 16-271 
CTS lost during message transmission, 16-302 
framing, 16-210, 16-387 | 
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glitches, 16-191 

heartbeat, 16-328 

idle sequence receive, 16-209, 16-387 

late collision, 16-328 

noise, 16-209 

nonoctet aligned frame, 16-235 

non-octet aligned packet, 16-356 

non-octet, 16-329 

overrun, 16-209, 16-235, 16-271, 16-302, 
16-328, 16-356, 16-387, 16-406 

parity, 16-209, 16-387 

retransmission attempts limit expired, 16-328 

SCC2 in ASYNC HDLC mode, 16-271 

SCC2 in Ethernet mode, 16-328 

SCC2 in HDLC mode, 16-234 

SCC2 in Transparent mode, 16-302 

SCC2 in UART mode, 16-208 

SMC in Transparent mode, 16-406 

SMC in UART mode, 16-387 

sync signals, 16-123 

transmit timeout, 16-356 

transmit underrun, 16-356 

transmitter underrun, 16-234, 16-302, 16-328 

TX data not ready, 16-356 

underrun, 16-406 

universal serial bus, 16-356 


Ethernet 


introduction to, 16-314 


Ethernet mode, SCC2, 16-311 
examples 


byte-working mode, 20-13 
CPM command register, 16-14 
CPM interrupt controller 

PC6, 16-500 

USB, 16-501 
DPLL encoding, 16-190 
DSP implementation, 16-37 
DSP programming (core and CPM), 16-39 
DSP programming for core, 16-38 
external bus master, 15-72 
general circuit interface, 16-147 
half-word working mode 1, 20-13 
half-word working mode 2, 20-14 
HDLC bus controller programming, 16-257 
HDLC interrupt event, 16-244 
hierarchical bus interface, 15-67 
IDL interface. 16-144 . 
initializing the RISC timers, 16-26 
‘instruction execution, 8-4 
interrupt table handling, 12-11 
LCD controller, 18-19 
memory system interface 


Index 


PCMCIA timing, 17-22 

port A configuration, 16-472 

port B configuration, 16-479 

RISC timer interrupt handling, 16-27 

SCC2 HDLC receive buffer descriptor, 16-238 

SCC2 in AppleTalk mode 
programming, 16-262 

SCC2 in ASYNC HDLC mode 
programming, 16-279 

SCC2 in Ethernet mode programming, 16-340 

SCC2 in Ethernet mode receive buffer 
descriptor, 16-332 

SCC2 in HDLC mode address 
recognition, 16-232 

SCC2 in HDLC mode programming, 
16-248, 16-249 

SCC2 in high-speed IrDA mode 
programming, 16-293 

SCC2 in low-speed IrDA mode 
programming, 16-290 

SCC2 in middle-speed mode 
programming, 16-291 

SCC2 in Transparent mode 
programming, 16-310 

SCC2 in UART mode programming, 16-224 

SCC2 in UART mode S-record 
programming, 16-226 

SCC2 UART interrupt event, 16-221 

SCC2 UART receive buffer descriptor, 16-215 

serial peripheral interface master 
programming, 16-443 

serial peripheral interface slave 
programming, 16-444 

slow device interface, 15-67 — 

SMC in Transparent mode programming 
NMSI, 16-413 | 


_ SMC in Transparent mode TSA 


programming, 16-414 
SMC in UART mode programming, 16-397 
SMC in UART mode receive buffer 
descriptor, 16-392 
SPI with different LEN values, 16-435 
timer initialization, 16-83 
translation reload, 11-50 
transparent synchronization, 16-299 
UART baud rate, 16-156 
universal serial bus initialization, 16-369 
video controller programming, 19-19 


exceptions, 20-28 


causes, 6-7 

control cycles, 13-41 
detecting, 6-9 
handling, 15-59 


page mode extended data-out, 15-89 PowerPC, 7-2 
page-mode DRAM, 15-77 sources, 6-7 
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execution, DSP, 16-75 
exiting from low-power mode, 5-28 
EXS (definition), 15-42 
EXTAL, 2-6 
EXTCLK, 2-6 
external accesses (definition), 15-68 
external bus masters, 15-68 
external bus, operating at lower frequencies, 5-17 
external hard reset, 4-3 
external interrupt 
latency, 6-13 
external memory access requests, 15- 43 
external soft reset, 4-4 


F 


features | 
baud rate generators, 16-151 
big endian mode, 14-5 
bus interface, 13-1 
clocks and power control, 5-1 
communication processor module, 16-1. . 
core, 6-1 | 
CPM interrupt controller, 16-489 
data cache, 10-1 
development capabilities, 20- 1 
digital signal processing, 16-28 
HDLC bus controller, 16-252 
lI2?C controller, 16-447 
IDMA, 16-91 
instruction cache, 9-1 
LCD controller, 18-1 
little endian mode, 14-3 
memory controller, 15-1 
memory management unit, 11- 1 
MPC823, 1-1 
not supported by SMC in UART mode, 16-382 
parallel I/O ports, 16-468 | 
PCMCIA, 17-1 
PowerPC little-endian mode, 14-5 — 
RISC microcontroller, 16-5 
RISC timer tables, 16-19 
SCC2 in AppleTalk mode, 16- 259 
SCC2 in ASYNC HDLC mode, 16-262. 
SCC2 in Ethernet mode, 16-312 | 
SCC2 in HDLC mode, 16-228 
SCC2 in Transparent mode, 16-295 
SCC2 UART controller, 16-196 | 
serial communication controller, 16-159 
serial interface, 16-115 | 
serial management controllers, 16-373 _ 
serial peripheral interface, 16-424 
SMC in GCI mode, 16-415 
SMC in Transparent mode, 16-399 
SMC in UART mode, 16-383 
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system interface unit, 12-2 
timers, 16-76 
universal serial bus, 16-343 
video controller, 19-2 
fetch serialization, causes of, 6- 12 
FIELD, 2-11 | 
filter, context-dependent, 20- 14. : 
finite impulse response (FIR) filter, 16-28 
FIR1 
applications, 16-43 : 
coefficients and sample data buffers, 16- At 
function descriptor, 16-42 
parameter packet, 16-43 
FIR2 
applications, 16-47 
coefficients and sample data buffers, 16-44 
function descriptor, 16-45 
parameter packet, 16-47 
FIRS 
applications, 16-51 
coefficients and sample data buffers, 16-49 
function descriptor, 16-49 
parameter RAM, 16-51 
FIR5 , 
applications, 16-55 
coefficients and sample data buffers, 16-52 
function descriptor, 16-53 
parameter RAM, 16-55 
FIR6 | 
coefficients and sample data buffers, 16- 56 
function descriptor, 16-57 
parameter packet, 16-59 
fixed-point exception cause register, 6-23 
fiag sequence, 16-266 
fly-by mode, 16-104 
FMO, 16-190 
FM1, 16-190 
format ; 
Ethernet frame, 16- 311 
high-speed IrDA, 16-285 
l2C controller memory, 16-457 
instructions, B-1 
level one descriptor, 11-9 
level two descriptor, 11-10 
LocalTalk frames, 16-258 
low-speed IrDA, 16-281 
middle-speed IrDA, 16-282 
SCC2 buffer descriptors, 16-173 
serial management controller memory, 16-374 
serial peripheral interface memory, 16-4382 
SMC in UART mode frames, 16-383 
UART character, 16-195 
universal serial bus commands, 16- oe 
video RAM word, 19-17 
fractional stop bits, 16-207 | 
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frame buffer A start address register, 18-25 
frame buffer B start address register, 18-26 
frame buffer, 18-5 
frame check sequence, 16-266 
frame length, maximum, 16-116 
frame reception 
SCC2 in ASYNC HDLC mode, 16-263 
SCC2 in Ethernet mode, 16-317 
SCC2 in HDLC mode, 16-229 
SCC2 in Transparent mode, 16-296 
SCC2 in UART mode, 16-200 
SMC in Transparent mode, 16-400 
SMC in UART mode, 16-384 
frame transmission 
SCC2 in ASYNC HDLC mode, 16-262 
SCC2 in Ethernet mode, 16-316 
SCC2 in HDLC mode, 16-228 
SCC2 in Transparent mode, 16-295 
SCC2 in UART mode, 16-200 
SMC in Transparent mode, 16-399 
SMC in UART mode, 16-383 
FRAME, 2-11 
free access override mode, 11-4 
frequencies, requirements for switching, 5-17 
frequency jitter, 5-14 
frequency of an application, 5-17 
frequency of interrupt routines, 5-17 
FRZ, 2-4, 20-30 
full-duplex operation, 16-252 
function descriptor (FD), 16-29 


G 


GCI (definition), 16-145, 16-415 
GCLKx frequency, 5-19 
GCLKx, 5-14 
GCLKx_50 frequency, 5-19 
GCLKx_50, 5-14 
GCLKxC, 5-14 
general circuit interface, 16-415 
activation and deactivation, 16-146 
operation, 16-145 
programming 
example, 16-147 
normal mode, 16-146 
SCIT mode, 16-147 
general-purpose chip-select machine, 15-28 
generating serial infra-red interaction pulses, 16-286 
glue logic, 15-5 
GND, 2-12 
GPCM (definition), 15-28 
GPL_AO, 2-5 
GPL_A1, 2-5 
GPL_A2, 2-6 
GPL_A3, 2-6 
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GPL_A4, 2-6 
GPL_AS5, 2-6 
GPL_BO, 2-5 
GPL_B1, 2-5 
GPL_B2, 2-6 
GPL_B3, 2-6 
GPL_B4, 2-6 
GPL_B5, 2-2 
GSMR_H, 16-160 
GSMR_L, 16-164 
guarded, 11-4 


H 


hard reset configuration word, 4-10 

hard reset, registers affected, 6-24 

hash table algorithm, 16-326 

HDLC (definition), 16-227 

HDLC bus controller, 16-250 
accessing, 16-253 
delayed RTS mode, 16-255 
performance, 16-254 | 
using the time-slot assigner, 16-256 

HDLC mode (SCC2), 16-227 

history buffer storage, 6-9 

history buffer, instructions that fill it, 6-9 

horizontal sync, 18-4 

HRESET, 2-6, 4-3 

HSYNC, 2-11 


I2ADD, 16-463 

l2BRG, 16-464 

l2C controller, 16-446 
address register (I2ADD), 16-463 
baud rate generator register (I2BRG), 16-464 
buffer descriptor ring, 16-457 
command register (I2COM), 16-464 
commands, 16-456 
event register (IZCER), 16-465 
features, 16-447 
mask register (IZ2CMR), 16-466 
memory map, 3-5 
mode register (I2MOD), 16-458 
operation, 16-447 
parameter RAM memory map, 16-453 
programming, 16-458 
receive buffer descriptor, 16-459 
transmission and reception, 16-448 
transmit buffer descriptor, 16-461 

I2CER, 16-465 

I2CMR, 16-466 

I2COM, 16-464 
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l2CSCL, 2-9 

lI2CSDA, 2-9 

l2MOD, 16-458 

l-address, 20-9 

IC_ADR, 9-6 

IC_CSR, 9-5 

IC_DAT, 9-7 

icbi, 11-48 

ICR, 20-55 

ICTRL, 6-17, 20-45 

IDG (definition), 16-259 

IDL (definition), 16-139 

IDL interface 
implementation, 16-140 
operation, 16-139 
programming, 16-143 

example, 16-144 

idle condition (definition), 16-195 

IDMA, 16-90 | 
buffer descriptors, 16-97 
commands, 16-101 
edge-sensitive mode, 16-102 
features, 16-91 
interface signals, 16-91 
level-sensitive mode, 16-102 
mask register, 16-96, 16-111 
operand transfers, 16-103 
operation, 16-91 
parameter RAM memory map, 16-93 
single address mode, 16-104 
single-buffer burst fly-by mode, 16-106 
starting, 16-102 
status register, 16-95, 16-110 
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IDMR, 16-96, 16-111 
IDSR, 16-95, 16-110 
IFG (definition), 16-259 
IIR, 16-59 
applications, 16-61 
coefficients and sample data buffers, 16-59 
function descriptor, 16-60 
parameter packet, 16-61 
image sizes, switching between, 19-4 
IMMR, 3-1, 6-18, 12-34 
implementation 
IDL interface, 16-140 
SCC2 ASYNC HDLC, 16-266 
implementing a precise exception model, 6-8 
IN token, 16-349 
infra-red encoder/decoder, 16-192 
initialization 
of the control registers, 6: 24 
serial communication controller, 16-182 
universal serial bus example, 16-369 
instruction address, 20-9 


instruction cache, 9-1 
address register, 9-6 
coherency, 9-14 
commands, 9-8 
CACHE DISABLE, 9-11 
CACHE ENABLE, 9-11 
INSTRUCTION CACHE BLOCK 
INVALIDATE, 9-9 
INVALIDATE ALL, 9-9 
LOAD & LOCK, 9-10 
UNLOCK ALL, 9-11 
UNLOCK LINE, 9-10 
control and status register, 9-5 
data path block diagram, 9-4 
data port register, 9-7 
debug support, 9-15 
disabling, 9-11 
enabling, 9-11 
features, 9-1 
inhibiting, 9-11 
instruction fetch on a predicted path, 9-8 
invalidating, 9-9 
operation, 9-7 
reading, 9-12 
reset, 9-14 
restoring the state of, 9-15 
restrictions, 9-14 
special-purpose control registers, 9-4 
updating code and memory region 
attributes, 9-14 
writing, 9-14 
instruction execution timing examples, 8-4 
instruction execution timing, 8-1 
insiruction fetch snow cycies, 20-6 
instruction flow (illustration), 6-3 
instruction register, 21-19 
instruction, long latency, 6-9 
instructions, B-1 
add, B-7 
addc, B-8 
adde, B-9 
addi, B-10 
addic, B-11 
addic., B-12 
addis, B-13 
addme, B-14 
addze, B-15 
and, B-16 
andc, B-17 
andi., B-18 
andis., B-19 
b, B-20 
bc, B-21 
bectr, B-23 
belr, B-25 


MPC823 USER’S MANUAL MOTOROLA 


instructions (continued) 


branch, 8-1 
bypass, 21-20 
cache control, 8-3 
clamp, 21-20 
cmp, B-27 

cmpi, B-28 

cmpl, B-29 

cmpli, B-30 
cntlzwx, B-31 
conditions for retiring from head of queue, 6-13 
CR logical, 8-1 
crand, B-32 
crandc, B-33 
creqv, B-34 
crnand, B-35 
crnor, B-36 

cror, B-37 

crorc, B-38 

crxor, B-39 

data cache, 10-3, 10-14 
dcbf, B-40 

debi, B-42 

dcbst, B-44 

debt, B-45 

dcbtst, B-46 
dcbz, B-47 

divw, B-49 

divwu, B-51 
eciwx, B-53 
ecowx, B-55 
eieio, B-57 

eqv, B-59 
execution results, 6-23 
extest, 21-19 


Index 


lbzux, B-67 

lbzx, B-68 

lha, B-69 

lhau, B-70 

lhaux, B-71 

lhax, B-72 

lhbrx, B-73 

Inz, B-74 

Ihzu, B-75 

lhzux, B-76 

lnzx, B-77 

Imw, B-78 

Iswi, B-79 

Iswx, B-81 

lwarx, B-83 

lwbrx, B-85 

lwz, B-86 

lwzu, B-87 

lwzux, B-88 

lwzx, B-89 

merf, B-90 

merxr, B-91 

mfcr B-93 

mfmsr, B-94 

mfspr, B-95 

mftb, B-99 

move condition register from XER, 8-2 
move from external to core, 8-1 
move from others, 8-2 

move from special registers, 8-1 
move to external to the core, 8-1 
move to LR, CTR, 8-1 

move to special 8-1 

move to/from special-purpose register, 8-2 
mtcrf, B-101 


extsb, B-60 mtmsr, B-102 

extsh, B-61 mtspr, B-103 

fields, B-2 mulhw, B-107 

fixed-point arithmetic (divide), 8-2 mulhwu, B-108 

fixed-point arithmetic (multiply), 8-2 mulli, B-109 

fixed-point arithmetic, 8-2 mullw, B-110 

fixed-point compare, 8-2 nand, B-111 

fixed-point load and store, 8-2 neg, B-112 

fixed-point load, 8-2 nonoptional, 7-1 

fixed-point logical, 8-2 nor, B-113 

fixed-point rotate and shift, 8-2 notations and conventions, B-3 

fixed-point store, 8-2 optional, 7-1 

fixed-point trap, 8-1 or, B-114 

format, B-1 orc, B-115 

hi-z, 21-20 order storage access, 8-3 

icbi, B-62 ori, B-116 

illegal and reserved, 7-1 oris, B-117 

isync, B-64 rfi, B-118 

lbz, B-65 rlwimi, B-119 

lbzu, B-66 rlwinm, B-121 
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rlwnm, B-123 
sample/preload, 21-20 
sc, B-125 

slw, B-126 
sraw, B-127 
srawi, B-128 
srw, B-129 

stb, B-130 
stbu, B-131 
stbux, B-132 
stbx, B-133 
sth, B-134 
sthorx, B-135 
sthu, B-136 
sthux, B-137 
sthx, B-138 
stmw, B-139 
storage control, 8-3 
storage synchronization, 8-2 
string, 8-2 
stswi, B-140 
stswx, B-141 
stw, B-142 
stwbrx, B-143 
stwcex, B-144 
stwu, B-146 
stwux, B-147 
stwx, B-148 
subf, B-149 
subfc, B-150 
subfe, B-151 
subfic, B-152 
subime, B-153 
subfze, B-154 
sync, B-155 
synchronize, 8-2 
system call, 8-1 
timing list, 8-1 
tlbia, B-156 
tlbie, B-157 
tlbsync, B-158 
tw, B-159 

twi, B-160 

xor, B-161 

xori, B-162 
xoris, B-163 


instructions, about, 


class, 7-1 

compression of, 20-8 
controlling the flow of, 6-5 
definitions, 7-1 

flow, 6-2 

invalid and preferred, 7-1 


issuing, 6-6 
serializing, 6-12 
interdialog gap, 16-259 
interface, development system, 20-20 
debug mode support, 20-22 
trap enable mode, 20-22 
interfacing with slow devices, 15-67 
interference, reducing, 5-19 
interframe gap, 16-259 
internal accesses (definition), 15-68 
internal arbiter, enabling, 13-41 
internal hard reset, causes of, 4-3 
internal memory map register, 3-1 
internal soft reset, 4-4 
interrupt controller memory map, 3-6 
interrupt generation, 5-28 
interrupt handler code, notification of 
restartability, 6-10 
interrupt latency, minimal, 6-13 
interrupt structure (illustration), 12-5 
interrupt vectors 
encoding, 16-494 
generating, 16-493 
interrupt, conditions for, 6-7 
interrupt, recovery from, 6-8 
interrupt, restarting after an, 6-10 
interrupts | 
classes, 7-7 
configuring, 12-5 
CPM interrupt controller, 16-500 
definitions, 7-8 
external, 6-13 
from SCC2, 16-181, 16-182 
highest priority, 16-490 
implementation-specific 
breakpoint, 6-10 
data TLB error, 11-48 
data TLB miss, 11-47 
debug port unmaskable, 6-10 
instruction TLB error, 11-48 
instruction TLB miss, 11-47 
masking sources in the CPM, 16-492 
memory management unit 
implementation-specific data TLB 
error, 11-48 
implementation-specific data TLB 
miss, 11-47 
implementation-specific instruction 
TLB error, 11-48 
implementation-specific instruction 
TLB miss, 11-47 
nested, 16-492 
on a serial interface RAM entry, 16-137 
order of detection, 6-14 
PCMCIA, 17-8 
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interrupts (continued) 
processing, 6-11, 7-8 
serial peripheral interface, 16-445 
SIU sources, 12-6 
SMC in Transparent mode, 16-415 
SMC in UART mode, 16-398 
system reset, 6-24 | 
types, 6-14 
invalidating the TLB, 11-51 
lOlIS16_B, 2-7 
IORD, 2-5 
lIOWR, 2-5 
IP_BO, 2-7 
IP_B1, 2-7 
IP_B2, 2-7 
IP_B3, 2-7 
IP_B4, 2-7 
IP_B5, 2-7, 2-8 
IP_B7, 2-8 
IrDA, 16-280 
4PPM data encoding, 16-283 
data link layer, 16-284 
high-speed, 16-283 
interaction pulses, 16-286 
IrDA (definition), 16-192 
low-speed, 16-281 
middle-speed, 16-282 
physical layer, 16-285 
programming 
high-speed example, 16-293 
low-speed example, 16-290 
middle-speed example, 16-291 
IRLAP (definition), 16-262 
IRMODE, 16-287 
IRQO, 2-4 
IRQ1, 2-4 
IRQ2, 2-3 
IRQ3, 2-3 
IRQ4, 2-3 
IRQ5, 2-4 
IRQ6, 2-4 
IRQ7, 2-4 
IRSIP, 16-289 
isochronous operation, 16-196 
IWPO, 2-7 
IWP1, 2-7 
IWP2, 2-7 


J 
JTAG (definition), 21-1 
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keep-alive power (KAPWR), 2-12, 5-25 
key register operation, 5-27 
KR, 2-3, 13-5 


L 


LiRCLKA, 2-8 

L1RQA, 2-10 

LIRSYNCA, 2-10 

LiRXDA, 2-8 

L1iST1, 2-9, 2-10 

L1ST3, 2-10 

L1ST4, 2-10 

LiST6, 2-10 

L1ST7, 2-10 

L1IST8, 2-10 

L1TCLKA, 2-9 

LITSYNCA, 2-10 

L1TXDA, 2-8 

L-address, 20-9 

latency, command execution, 16-14 

latency, interrupt, 6-11 

LCCR, 18-20 

LCD controller 
block diagram, general, 18-6 
color RAM, 18-28 


active four- and eight-bit color mode, 18-34 


four-bit/pixel grayscale mode, 18-31 
one-bit/pixel monochrome mode, 18-28 
passive, four- and eight-bit color 
mode, 18-33 
two-bit/pixel grayscale mode, 18-30 
contrast and brightness control, 18-13 
DMA control, 18-12 
features, 18-1 
FIFO, 18-8 
frame control, 18-12 
horizontal control, 18-12 
interface, 18-3, 18-13 
active, 18-16 
analog, 18-18 
passive, 18-14 
single- and dual-scan panels, 18-14 
LCD clocks, 5-21 
memory map, 3-5 
operation, 18-7 
panel connection examples, 18-35 
pixel generation, 18-9 
color, 18-11 
grayscale, 18-9 


index 


LCD controller (continued) 
registers, 18-20 
configuration register (LCCR), 18-20 
frame buffer A start address register 
_ (LCFAA), 18-25 
frame buffer B start address register 
(LCFBA), 18-26 
horizontal control register (LCHCR), 18-22 
status register (LCSR), 18-27 
vertical controler register (LCVCR), 18-23 
system considerations, 18-18 
timing control, 18-13 
vertical control, 18-12 | 
LCD horizontal control register, 18-22 
LCD status register, 18-27 
LCD technology, 18-2 
LCD vertical control register, 18-23 
LCD_A, 2-9 
LCD_AC, 2-11 
LCD_B, 2-9 
LCD_C, 2-10 
LCDCLK and LCDCLKS50 frequency, 5-21 
LCDCLK, 5-21 
LCDCLKSO, 5-21 
LCFAA, 18-25 
LCFBA, 18-26 
LCHCR, 18-22 
LCSR, 18-27 
LCTRL1, 20-48 
LCTRL2, 20-50 
LCTRLx, 6-17 
LCVCR, 18-23 
LDO, 2-11 
LD1, 2-11 
LD2, 2-11 
LD3, 2-11 
LD4, 2-11 
LD5, 2-11 
LD6, 2-11 
LD7, 2-11 
LD8, 2-11 
L-data, 20-9 
LEN values, 16-435 
level interrupt, 12-7 
level sensitive IDMA, 16-91 
library, DSP, 16-40 
limitations, of the USB host, 16-344 
linefeed, 16-226 
little-endian SDMA, 16-85 
LMS1, 16-67 
applications, 16-69 
coefficients and sample data buffers, 16-67 
function descriptor, 16-68 
parameter packet, 16-69 
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LMS2, 16-69 
applications, 16-72 
coefficients and sample data buffers, 16-70 
function descriptor, 16-70 
parameter packet, 16-72 

load (instruction), 10-12 

LOAD, 2-11 

load/store address, 20-9 

load/store data, 20-9 

LOE, 2-11 

loopback mode (local), 16-168 

loopback mode, 16-116 

loopback, 16-327 

loopback/echo mode, 16-169 

loops, nesting, 15-59 

low-power divider, 5-14 

low-power mode (illustration), 5-29 
power consumption equations, 5-31 

low-power stop operation, 12-28 

low-power, operating at, 5-28 

lwarx, 13-38 

LWPO, 2-7 

LWP1, 2-7, 2-8 


M_CASID, 11-18 
M_TW, 11-37 
M_TWB, 11-36 
MAC (definition), 16-4 | 
machine A mode register, 15-19 
machine B mode register, 15-23 
MAMR, 15-19 
Manchester, 16-191 
MAR, 15-27 
master, 16-425 
MBMR, 15-23 
MCR, 15-17 
MD_AP, 11-32 
MD_CAM, 11-38 
MD_CTR, 11-17 
MD_EPN, 11-20 
MD_RAMO, 11-39 
MD_RAM1, 11-41 
MD_RPN, 11-26 
MD_TWC, 11-34 
MDR, 15-26 
mechanicals, 23-1 
pin assignment, 23-2 
memory access, controlling, 15-41 
memory address register, 15-27 
memory coherence, 7-4, 11-4 
memory command register, 15-17 
memory controller, 15-1 
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architecture, 15-4 
baud rate generator clock, 5-19 
block diagram, 15-3 
external masters, 15-68 
examples, 15-72 
types, 15-68 
features, 15-1 
GPCM configuration, 15-28 
memory map, 3-2 
memory system interface examples, 15-77 
registers, 15-7 
transfers, 13-25 
UPMs 
block diagram, 15-41 
Clock timing, 15-45 
programming, 15-44 
RAM array, 15-48 
requests, 15-42 
wait mechanism, 15-65 
memory data register, 15-26 
memory management unit, 11-1 
accessing the control registers, 11-52 
address translation, 11-2 
features, 11-1 
interrupts, 11-47 
programming, 11-15 
control registers, 11-16 
data status registers, 11-37 
instruction status registers, 11-43 
protection, 11-3 
storage control, 11-4 
TLB manipulation, 11-49 
translation lookaside buffers, 11-2 
translation table structure, 11-5 
level one descriptor, 11-9 
level two descriptor, 11-10 
memory map, 3-1 
baud rate generators, 3-8 
clocks and reset keys, 3-4 
clocks and reset, 3-4 
communication processor module, 3-8 
CPM interrupt controller, 3-6 
CPM timer, 3-7 
DMA cortroller, 3-6 
dual-port RAM, 3-11 
HDLC bus controller, 16-257 
l2C controller, 3-5, 16-453 
LCD controller, 3-5 
memory controller, 3-2 
parallel ports, 3-6 
PCMCIA, 3-2 
Port B, 3-10 
SCC2 in ASYNC HDLC mode, 16-267 
SCC2 in Ethernet mode, 16-318 
SCC2 in HDLC mode, 16-230 
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SCC2 in Transparent mode, 16-300 
SCC2 in UART mode, 16-198 
serial communication controller, 3-9, 16-176 
serial interface, 3-11 
serial management controllers, 3-9, 
3-10, 16-375 
serial peripheral interface, 3-10, 16-428 
SMC in GCI mode, 16-417 
SMC in Transparent mode, 16-405 
SMC in UART mode, 16-384 
specialized RAM, 3-11 
system integration timer keys, 3-4 
system integration timers, 3-3 
system interface unit, 3-1 
universal serial bus, 3-8, 16-350 
video controller, 3-4 
memory periodic timer prescaler register, 15-28 
memory status register, 15-15 
memory structure, SCC2, 16-174 
mfspr, 10-4, 11-15, 12-13 
mftb, 12-14 
mftbu, 12-14 
Mi_AP, 11-31 
MI_CAM, 11-43 
Mi_CTR, 11-16 
Mi_EPN, 11-19 
MI_RAMO, 11-45 
MI_RAM1, 11-46 
MI_RPN, 11-21 
MI_TWC, 11-33 
microcode configurations, 16-9 
microcode, executing from RAM or ROM, 16-7 
MMU registers 
current address space ID register, 11-18 
data access protection register, 11-32 
data CAM entry read register, 11-38 
data control register, 11-17 
data effective page number, 11-20 
data RAM entry read register 0, 11-39 
data RAM entry read register 1, 11-41 
data real page number register, 11-26 
data tablewalk control register, 11-34 
instruction access protection register, 11-31 
instruction CAM entry read register, 11-43 
instruction control register, 11-16 
instruction effective page number 
register, 11-19 
instruction RAM entry read register 0, 11-45 
instruction RAM entry read register 1, 11-46 
instruction real page number register, 11-21 
instruction tablewalk control register, 11-33 
tablewalk base register, 11-36 
tablewalk special register, 11-37 
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MOD 
applications, 16-64 
function descriptor, 16-63 
modulation table and sample data buffers, 16-62 
parameter packet, 16-64 
MODCK1 and MODCK2, 2-8, 5-22 
modes 
copyback, 10-11 
data cache, 10-10 
switching between, 5-30 
writethrough, 10-12 
MPC821 compared to MPC823, 1-13 
MPC821 and SCC2, 16-159 
MPC823 
about the, 1-1 
block diagram, 1-8 
clocks, 5-10 
communication processor module, 16-1 
compared with MPC821, 1-13 
core, 6-1 
data cache, 10-1 
debugging, 9-15, 10-12 
development capabilities, 20-1 
electrical characteristics, 22-1 
endian modes, 14-1 
Ethernet, 16-313 
external bus interface, 13-1 
features, 1-1 
general system (illustration), 14-2 
IEEE 1149.1 test access port, 21-1 
instruction cache, 9-1 
instruction set, B-6 
IrDA, 16-280 


[CD controller, 18-1 | 
mechanical data and ordering information, 23-1 
memory controller, 15-1 | 
memory management unit, 11-1 
PCMCIA interface, 17-1 
power supply, 5-25 
signals, 2-1 
system interface unit, 12-1 
terminology, 24-1 
video controller, 19-1 

MPTPR, 15-28 

MSR, 6-19, 6-20, 7-9 

MSTAT, 15-15 

mtmsr, 14-5 

mtspr, 10-4, 11-15, 12-13, 14-5 

mttb, 12-14 

mttbu, 12-14 

multibuffer operation, 16-200 

multidrop environment, 16-202 
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N/C, 2-12 
NMI (definition), 12-6 
NMSI 
configuration, 16-148 
features, 16-115 
NMSI (definition), 16-113 
no access override mode, 11-4 
no override mode, 11-4 
noise, reducing, 5-19 
NRZ, 16-190 
NTSC (definition), 19-20 


O 


OE, 2-5 
OHCI (definition), 16-344 
OP2 and OPS, 2-8 
Open Host Controller Interface, 16-344 
operand placement (effects), 7-4 
operating frequencies, reducing and restoring, 5-15 
operation 
address translation, 11-2 
autobaud, 16-153 
boot chip-select, 15-38 
bus interface, 13-7 
clocks, 5-10 
CPM interrupt controller, 16-487 
data cache, 10-10 
digital phase-locked loop, 16-187 
DSP, 16-28 
endian mode, 14-5 
freeze, 12-28 
general circuit interface, 16-145 
general-purpose chip-select machine, 15-28 
HDLC bus controller, 16-250 OS 
lI2C controller, 16-447. 
IDL interface, 16-139 
instruction cache, 9-7 
IrDA, 16-192 
LCD controller, 18-7 
LocalTalk, 16-258 
low-power, 5-28 
low-speed IrDA, 16-281 
memory controller (illustration), 15-7 
parallel I/O ports, 16-467 
PCMCIA I/O cards, 17-7 
PCMCIA memory-only cards, 17-7 
PCMCIA, 17-7 
port A, 16-468 
port B, 16-474 
port C, 16-479 
port D, 16-485 
power control, 5-24 
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operation (continued) 
program flow tracking, 20-3 
RAM word, 15-54 
register unit of the core, 6-15 
SCC2 in Ethernet mode, 16-311, 16-313 
SCC2 in HDLC mode, 16-227 
SCC2 in IrDA mode, 16-280 
SCC2 in Transparent mode, 16-294 
SCC2 in UART mode, 16-195 
SDMA, 16-86 
sequencer unit of the core, 6-4 
serial interface RAM, 16-118 
serial management controllers, 16-372 
serial peripheral interface 
multimaster, 16-427 
serial peripheral interface, 16-425 
SMC in GCI mode, 16-415 
timers, 16-77 
translation lookaside buffers, 11-2 
universal serial bus, 16-342 
user-programmable machines, 15-41 
video controller, 19-2 
watchpoints and breakpoints, 20-16 
operations that support endian modes, 14-2 
option registers, 15-11 
ordering information, 23-1 
oscillator, main clock, 5-12 
advantages, 5-10 
OSCM, 5-12 
OSI (definition), 16-227 
OSSCLK, 5-12 
OUT token, 16-348 
output enable, 18-4 


p 


package dimensions, 23-3 

PADAT, 16-470 

PADIR, 16-471 

PAL (definition), 19-24 

PAODR, 16-470 

PAPAR, 16-471, 16-487 

parallel I/O ports, 16-467 
features, 16-468 
memory map, 3-6 
operation, 16-467 
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port B 
configuration example, 16-479 
operation, 16-474 
pins, 16-474 
registers 
data direction (PBDIR), 16-477 
data (PBDAT), 16-476 
open-drain (PBODR), 16-475 
pin assignment (PBPAR), 16-478 
port C 
operation, 16-479 
pins, 16-479 
registers 
data (PCDAT), 16-482 
data direction (PCDIR), 16-482 
interrupt control (PCINT), 16-484 
pin assignment (PCPAR), 16-483 
special options (PCSO), 16-483 
port D 
operation, 16-485 
pins, 16-485 
registers, 16-486 
data (PDDAT), 16-486 
data direction (PDDIR), 16-486 
pin assignment (PDPAR), 16-487 
parameter RAM memory map 
DSP, 16-32 
l2C controller, 16-453 
IDMA, 16-93 
RISC timer tables, 16-19 
SCC2 in ASYNC HDLC mode, 16-267 
SCC2 in Ethernet mode, 16-318 
SCC2 in HDLC mode, 16-230 
SCC2 in Transparent mode, 16-300 
SCC2 in UART mode, 16-198 
serial peripheral interface, 16-428 
SMC in GCI mode, 16-417 
SMC in Transparent mode 16-405 
SMC in UART mode, 16-384 
universal serial bus, 16-350 
parameter RAM, structure, 16-17 
parameter storage, 16-32 
parity error, 15-7, 15-8 
parity, configuring, 15-8 
patterns, preamble, 16-189 
PBDAT, 16-476, 16-482 
PBDIR, 16-477 


port A noe _ 

examples, 16-472 ae here 

registers “an: 
data direction (PADIR), 16-471 Sieh ure 
data (PADAT), 16-470 PCDIR 16-482 
eel alee mca ae PCI bridge (definition), 14-2 
pin assignment (PAPAR), 16-471 PCINT. 16-484 
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PCMCIA, 17-1 
configuration, 17-1 
features, 17-1 
memory map, 3-2 
operation 
DMA, 17-8 
I/O cards, 17-7 
interrupts, 17-8 | 
memory-only cards, 17-7 
power control, 17-8 
reset and three-state, 17-8 
programming, 17-9 
registers 
base (PBRx), 17-16 
interface enable (PER), 17-13 
interface general control register B 
(PGCRB), 17-15 
interface input pins (PIPR), 17-9 
interface status change (PSCR), 17-11 
option (PORx), 17-17 
signals, 17-3 
timing examples, 17-22 
PCOE, 2-5 
PCPAR, 16-483 
PCSO, 16-483 
PCWE, 2-5 
PDA example, 16-4 
PDDAT, 16-486 
PDDIR, 16-486 
PER, 17-13 
performance 
achieving the best, 5-24 
Ethernet, 16-326 


HDLC bus controller, 16-254 
maximizing, 9-15 
periodic interrupt count register key, 5-27 
periodic interrupt status and control register 
key, 5-27 
periodic interrupt status and control register, 12-23 
periodic interrupt timer block diagram, 12-22 
periodic interrupt timer count register, 12-24 
periodic interrupt timer register, 12-25 
periodic interrupt timer, 12-22 
periodic timers, 15-43 
PGCRB, 17-15 
phase jitter, 5-14 
phase skew, 5-13 
pin assignments 
port A, 16-469 
port B, 16-474 
port C, 16-479 
port D, 16-485 
PWM channels, 16-24 
pinout diagram, 2-1 
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pins, 2-1 
assignment, 23-2 
development support, 20-29 
NMSI, 16-150 
system interface unit, 12-29 
unconnected, 2-12 
universal serial bus, 16-346 
pipeline bubbles, cause of, 6-5 
PIPR, 17-9 
PISCR, 12-23 
PISCRK, 5-27 
PITC, 12-24 
PITCK, 5-27 
PITR, 12-25 
pixel generation, 18-9 
PLL, 13-7 
PLL, low power, and reset control register, 5-7 
PLL, low-power and reset control register key, 5-27 
PLPRCRK, 5-27 
PORESET, 2-6, 4-2 
port A 
data direction register, 16-471 
data register, 16-470 
open-drain register, 16-470 
pin assignment register, 16-471 
Port B 
memory map, 3-10 
port B 
data direction register, 16-477 
data register, 16-476 
open-drain register, 16-475 
pin assignment register, 16-478 
port C 
data direction register, 16-482 
data register, 16-482 
interrupt control register, 16-484 
pin assignment register, 16-483 
special options register, 16-483 
port D 
data direction register, 16-486 
data register, 16-486 
pin assignment register, 16-487 
port width (definition), 13-2 
ports, special to MSR, 6-11 
PORx, 17-17 
power 
conserving, 5-19, 9-7, 10-11, 16-194 
keep-alive power 
register locking, 5-27 
operation, 5-24 
PCMCIA, 17-8 
planes, 5-24 
rails, 5-24 
switching schemes, 5-26 
power supply pins, 2-12 
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power supply requirements, 5-25 
power-down mode, exiting from, 5-30 
power-on reset, 4-2 
state of key registers, 5-27 
PowerPC core 
about the, 6-1 
basic structure, 6-2 
features, 6-1 
PowerPC standards 
PowerPC Operating Environment Architecture 
(Book 3) 
branch processor, 7-6 
fixed-point processor, 7-6 
interrupts, 7-7 
optional facilities and instructions, 7-17 
reference and change bits, 7-7 
storage control instructions, 7-7 
storage model, 7-6 
timer facilities, 7-17 
PowerPC User Instruction Set Architecture 
(Book 1) 
branch instructions, 7-2 
branch processor, 7-2 
computation modes, 7-1 
exceptions, 7-2 
fixed point-processor, 7-2 
instruction classes, 7-1 
load/store processor, 7-3 
reserved fields, 7-1 
PowerPC Virtual Environment Architecture 
(Book 2) 
operand placement effects, 7-4 
storage control instructions, 7-5 
storage model, 7-4 
timebase, 7-5 
PPM (definition), 16-283 
PPP (definition), 16-262 
PRE token, 16-350 
preamble, sending, 16-206 
processor, state of, 6-20 
program flow tracking, 20-2 
program trace cycle (definition), 20-3 
program trace, reconstructing, 20-2 
programming 
CPM interrupt controller, 16-495 
data cache, 10-3 
development port, 20-41 
DSP, 16-29 
general circuit interface, 16-146 
HDLC bus controller, 16-257 
IDL interface, 16-143 
instruction cache, 9-4 
memory management unit, 11-15 
PCMCIA, 17-9 
SCC2 in AppleTalk mode, 16-261 
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SCC2 in ASYNC HDLC mode example, 16-279 
SCC2 in ASYNC HDLC mode, 16-272 
SCC2 in Ethernet mode example, 16-340 
SCC2 in Ethernet mode, 16-329 
SCC2 in HDLC mode example, 16-248, 16-249 
SCC2 in HDLC mode, 16-232 
SCC2 in IrDA mode, 16-287 
SCC2 in low-speed IrDA mode 
example, 16-290 
SCC2 in middle-speed IrDA mode 
example, 16-291 
SCC2 in Transparent mode example, 16-310 
SCC2 in UART mode example, 16-224 
SCC2 in UART mode S-record 
example, 16-226 
SCC2 in UART mode, 16-200 
SCC2 Transparent mode patterns, 16-297 
serial interface RAM, 16-120 
serial peripheral interface master 
example, 16-443 
serial peripheral interface slave 
example, 16-444 
serial peripheral interface, 16-433 
SIU interrupt controller, 12-7 
SMC in Transparent mode NMS! 
example, 16-413 
SMC in Transparent mode TSA 
example, 16-414 
SMC in UART mode example, 16-397 
SMC in UART mode, 16-385 
SPLL, 5-1 
system interface unit, 12-30 
time-slot assigner, 16-116 
TLB replacement counter, 11-51 
universal serial bus, 16-357 
user-programmable machines, 15-44 
video controller, 19-5 
promiscuous operation, 16-294 
protocols | 
asynchronous, 16-187 
SCC2 in ASYNC HDLC mode, 16-262 
SCC2 in Ethernet mode, 16-311 
SCC2 in HDLC mode, 16-227 
SCC2 in IrDA mode, 16-280 
SCC2 in Transparent mode, 16-294 | 
SCC2 in UART mode, 16-195 
SMC in GCI mode, 16-415 
SMC in Transparent mode, 16-399 
SMC in UART mode, 16-382 
switching, 16-194, 16-382 
synchronous, 16-183 
PSCR, 17-11 
PSMR (general), 16-170 
PSMR-SCC2 ASYNC HDLC, 16-272 
PSMR-SCC2 Ethernet, 16-329 
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PSMR-SCC2 HDLC, 16-236 
PSMR-SCC2 UART, 16-211 
PTR, 2-8, 13-4 

PTS (definition), 15-42 
pull-up resistors, 16-467 
pulses, 16-286 

PWM (definition), 16-19 


R 


raindrop effect, 18-3 
RAM addresses, serial interface RAM, 16-124 
RAM array and signal generation, 15-48 
size, 15-48 
indexing service requests, 15-43 
RAM word 
definition, 15-49 
format, 15-49 
operation, 15-54 
storing, 15-43 
RAM, video control, 19-16 
RBS (definition), 15-42 
RCCR, 16-8 
RCLK, 16-314 
RD/WR, 2-2, 13-4, 13-32 
read accesses, extending hold time, 15-35 
read hit, 10-10 
read miss, 10-10 
real-time clock, 12-17 
block diagram, 12-17 
registers 
alarm register key, 5-27 
alarm seconds key, 5-27 
alarm register, 12-21 
alarm seconds register, 12-20 
register key, 5-27 
register, 12-19 
status and control register key, 5-27 
status and control register, 12-18 
reference bit updates, 11-4 
register unit, of the core, 6-15 
registers 
baud rate generator configuration, 16-154 
boundary scan, 21-4 
breakpoint address, 20-44 
breakpoint counter A value and control, 20-53 
breakpoint counter B value and control, 20-54 
comparator A-D value, 20-42 
comparator E-F value, 20-43 
comparator G-H value, 20-43 
condition, 6-22 
control, 6-16 
CPM command, 16-10 
CPM interrupt controller, 16-495 
data cache (special), 10-4 
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data cache address, 10-7 

data cache control and status, 10-5 
data synchronization, 16-171 

debug enable, 20-57 

decrementer, 12-13 

development port data, 20-60 
development port shift, 20-30 

DSP event, 16-35 

DSP mask, 16-36 

fixed-point exception cause, 6-23 

frame buffer A start address set 0, 19-11 
frame buffer A start address, 18-25 
frame buffer B start address, 18-26 
general SCC mode high and low, 16-160 
general SMC mode, 16-374 

l?C address, 16-463 

l?C baud rate generator, 16-464 

l?C command, 16-464 

I?C event, 16-465 

lI?C mask, 16-466 

lI2C mode, 16-458 

IDMA mask, 16-96, 16-111 

IDMA status, 16-95 

IDSR, 16-110 

instruction cache address, 9-6 
instruction cache control and status, 9-5 
instruction cache data port, 9-7 
instruction support control, 20-45 
internal memory map, 3-1, 12-34 
interrupt cause, 20-55 

key, 3-4, 5-27 

LCD controller configuration, 18-20 
load/store support AND-OR control, 20-50 
load/store support comparators control, 20-48 
machine A mode, 15-19 

machine B mode, 15-23 

machine state, 6-20 

memory address, 15-27 

memory command, 15-17 

memory controller base, 15-9 

memory controller option, 15-11 

memory controller, 15-7 

memory data, 15-26 

memory periodic timer prescaler, 15-28 
memory status, 15-15 

MMU current addresss space ID, 11-18 
MMU data access protection, 11-32 
MMU data CAM entry read, 11-38 

MMU data control, 11-17 

MMU data effective page number, 11-20 
MMU data RAM entry read 0, 11-39 
MMU data RAM entry read 1, 11-41 
MMU data real page number, 11-26 
MMU data tablewalk control, 11-34 
MMU instruction access protection, 11-31 
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MMU instruction CAM entry read, 11-43 

MMU instruction control, 11-16 

MMU instruction effective page number, 11-19 

MMU instruction RAM entry read 0, 11-45 

MMU instruction RAM entry read 1, 11-46 

MMU instruction real page number, 11-21 

MMU instruction tablewalk control, 11-33 

MMU tablewalk base, 11-36 

MMU tablewalk special, 11-37 

PCMCIA base, 17-16 

PCMCIA interface enable, 17-13 

PCMCIA interface general control 
register B, 17-15 

PCMCIA interface input pins, 17-9 

PCMCIA interface status change, 17-11 

PCMCIA option, 17-17 

periodic interrupt status and control, 12-23 

periodic interrupt timer count, 12-24 

periodic interrupt timer, 12-25 

PLL, low power, and reset control, 5-7 

port A data direction, 16-471 

port A data, 16-470 

port A open-drain, 16-470 

port A pin assignment, 16-471 

port A, 16-470 

port B data direction, 16-477 

port B data, 16-476 

port B open-drain, 16-475 

port B pin assignment, 16-478 

port B, 16-475 

port C data direction, 16-482 

port C data, 16-482 

port C interrupt control, 16-484 

port C pin assignment, 16-483 

port C special options, 16-483 

port C, 16-481 

port D data direction, 16-486 

port D data, 16-486 

port D pin assignment, 16-487 

port D, 16-486 

protocol-specific mode, 16-170 

real-time clock alarm seconds, 12-20 

real-time clock alarm, 12-21 

real-time clock status and control, 12-18 

real-time clock, 12-19 

reset status, 4-5 

RISC controller configuration, 16-8 

RISC microcode development support 
control, 16-7 

RISC timer event, 16-25 

RISC timer mask, 16-25 

SCC2 ASYNC HDLC event, 16-277 

SCC2 ASYNC HDLC mode, 16-272 

SCC2 Ethernet event, 16-338 
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SCC? Ethernet mask, 16-340 

SCC2 Ethernet mode, 16-329 

SCC2 Ethernet status, 16-340 

SCC2 event, 16-181 

SCC2 HDLC event, 16-243 

SCC2 HDLC mask, 16-246 

SCC2 HDLC mode, 16-236 

SCC2 HDLC status, 16-247 

SCC2 infra-red serial interaction pulse 
control, 16-289 

SCC2 mask, 16-181 

SCC2 serial infra-red mode, 16-287 

SCC2 status, 16-181 

SCC2 Transparent event, 16-307 

SCC2 Transparent mask, 16-309 

SCC2 Transparent status, 16-309 

SCC2 UART event, 16-221 

SCC2 UART mask, 16-223 

SCC2 UART status, 16-224 

SDMA address, 16-90 

SDMA configuration, 16-87 

SDMA mask, 16-89 


SDMA status, 16-88 


SDMA, 16-87 

serial interface clock route, 16-134 

serial interface command, 16-136 

serial interface global mode, 16-126 

serial interface mode, 16-127 

serial interface RAM pointer, 16-137 

serial interface status, 16-137 

SIU interrupt edge/level, 12-9 

SIU interrupt mask, 12-8 - 

SIU interrupt pending, 12-7 

SIU interrupt vector, 12-10 

SIU module configuration, 12-30 

SMC GCI event, 16-422 

SMC GCI mask, 16-423 

SMC in GCI mode, 16-421 

SMC transparent event, 16-412 

SMC transparent mask, 16-413 

SMC transparent mode, 16-406 

SMC UART event, 16-395 

SMC UART mask, 16-397 

SMC UART mode, 16-388 

software service, 12-27 

special-purpose, 6-16 
unsupported registers, 7-6 

SPI command, 16-441. 

SPI event, 16-442 

SPI mask, 16-443 

SPI mode, 16-433 

system clock and reset control, 5-3 

system protection control, 12-35 

test access port instruction, 21-19 

timebase reference, 12-15 
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registers (continued) 
timebase status and control, 12. 16 
timebase, 12-14 
timer capture, 16-82 
timer counter, 16-82 
timer event, 16-83 
timer global configuration, 16-78, 16- 79 
timer mode, 16-80 
timer reference, 16-81 
transfer error status, 12-36 
transmit-on-demand, 16-171 
trap enable control, 20-31 
universal serial bus command, 16-364 
universal serial bus endpoint, 16-365 
universal serial bus event, 16-368 
universal serial bus mask, 16-369 
universal serial bus mode, 16-357 
universal serial bus slave address, 16-363 
universal serial bus status, 16-369 
video background color buffer, 19-9 
video command, 19-8 
video controller configuration, 19-5 
video frame buffer A start address set 1, 19-14 
video frame buffer B start address set 0, 19-12 
video frame buffer B start address set 1, 19-15 
video frame configuration set 0, 19-10 
video frame configuration set 1, 19-13 
video status, 19-7 
write-protected, 5-27 

registers (special) outside of the core 
encoding, 6-19 

requests to initiate a UPM cycle, 15-42 | 
exception, 15-44 


memory access, 1 5-Ag 


memory periodic timer, 15-43 
software, 15-43 
reset, 4-1 
configuration 
hard reset, 4-7 
soft reset, 4-12 
hard reset configuration word, 4-10 
instruction cache, 9-14 
PCMCIA, 17-8 
results at, 4-1 
status register key, 5-27 
status register, 4-5 
types, 4-2 


resetting the registers and parameters for all the 


channels, 16-10 
resolution, 16-77 
restartability (interrupts), 6-10 
restrictions on the MPC823, 21-21 
RETRY, 2-3, 13-5, 13-41 
RFC 1549 | 
exceptions, 16-266 
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rfi, 16-495, 16-499, 16-500, 16-501 
RISC microcontroller, 16-4 

RISC timer event register, 16-25 
RISC timer initialization example, 16-26 
RISC timer interrupt example, 16-27 
RISC timer mask register, 16-25 
RISC timer table algorithm, 16-27 
RMDS, 16-7 

RS-232 standard, 16- 195 

RSR, 4-5 

RSRK, 5-27 

RSS (definition), 15-42 
RSTCONF, 2-6 

RSV, 2-3, 13-4 

RTC, 12-19 

RTCAL, 12-21 

RTCALK, 5-27 

RTCK, 5-27 

RTCSC, 12-18 

RTCSCK, 5-27 

RTER, 16-25 

RTMR, 16-25 

RTS2, 2-10 

RTSEC, 12-20 


. RTSECK, 5-27 


RXD, 16-314 
RXD2, 2-8 


S 


S/T (definition), 16-145 

SCC2 (definition), 16-157 
SCC2 and USB priority, 16-490 
SCCE, 16-181 
SCCE-ASYNC HDLC, 16-277 
SCCE-Ethernet, 16-338 
SCCE-HDLC, 16-243 
SCCE-Transparent, 16-307 
SCCE-UART, 16-221 

SCCM, 16-181 
SCCM-—Ethernet, 16-340 
SCCM-—HDLC, 16-246 
SCCM-Transparent, 16-309 
SCCM-UART, 16-223 

SCCR, 5-3 

SCCRK, 5-27 

SCCS, 16-181 
SCCS-—Ethernet, 16-340 
SCCS-HDLC, 16-247 
SCCS-—Transparent, 16-309 
SCCS-UART, 16-224 | 
schematic of the MPC823, 23-3 
SCIT (definition), 16-145 
scratchpad, 16-32 

SDACK1, 2-9, 2-10 
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SDACK2, 2-9 
SDACKx, about, 16-91 
SDAR, 16-90 
SDCR, 16-87 
SDMA, 16-84 
address register, 16-90 
configuration register, 16-87 
definition, 16-4 
mask register, 16-36 
status register, 16-35, 16-88 
SDMR, 16-36, 16-89 
SDSR, 16-35, 16-88 
selecting a general system clock, 5-17 
selecting a machine, 15-4 
self-refresh mode, exiting, 15-43 
sequence of interrupt detection, 6-14 
sequencer unit, of the core, 6-4 
serial communication controller, 16-157 
AppleTalk mode, 16-258 
connectivity, 16-260 
features, 16-259 
operation, 16-258 
programming, 16-261, 16-262 
ASYNC HDLC mode 
16-262 
commands, 16-270 
configuration, 16-269 
errors, 16-271 
event register (SCCE-ASYNC 
HDLC), 16-277 
features, 16-262 
frame reception, 16-263 
frame transmission, 16-262 
implementation, 16-266 
mode register (PSMR-SCC2 ASYNC 
HDLC), 16-272 
parameter RAM memory map, 16-267 
programming guide, 16-279 
receive buffer descriptor, 16-273 
transmit buffer descriptor, 16-275 
block diagram, 16-158 
buffer descriptor format, 16-173 
clock glitches, 16-191 
data synchronization register (DSR), 16-171 
digital phase-locked loop, 16-187 
disabling on-the-fly, 16-193 
Ethernet mode, 16-311 
address recognition, 16-324 
collision handling, 16-327 
commands, 16-323 
configuration, 16-322 | 
connecting to EEST, 16-314 
errors, 16-328 
event register, 16-338 
features, 16-312 — 
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frame reception, 16-317 
frame transmission, 16-316 
hash table algorithm, 16-326 
interpacket gap time, 16-327 
loopback and full-duplex operation, 16-327 
mask register, 16-340 
mode register (PSMR-Ethernet), 16-329 
operation, 16-311 
parameter RAM memory map, 16-318 
programming example, 16-340 
receive buffer descriptor, 16-332 
status register, 16-340 
transmit buffer descriptor, 16-335 
event register (SCCE), 16-181 
features, 16-159 
general SCC mode high register 
(GSMR_H), 16-160 
general SCC2 mode low register 
(GSMR_L), 16-165 
HDLC bus controller, 16-250 
features, 16-252 
memory map and programming, 16-257 
HDLC mode ; 
commands, 16-233 
errors, 16-234 
event register (SCCE- HDLC), 16-243 
frame reception, 16-229 
frame transmission, 16-228 
mask register (SCCM-HDLC), 16-246 
mode register (PSMR-SCC2 
HDLC), 16-236 
operation, 16-227 
programming, 16-232 
receive buffer descriptors, 16-237 
status register (SCCS-HDLC), 16-247 
transmit buffer descriptor, 16-241 
initialization, 16-182 
interrupts, 16-181 
IrDA mode, 16-280 
data link layer, 16-284 
high-speed, 16-283 
programming example, 16-293 
infra-red interaction pulses, 16-286 
infra-red serial interaction pulse control 
register (IRSIP), 16-289 
low-speed, 16-281 
programming Scanisies 16- 290 
middle-speed, 16-282 
programming example, 16-291 
physical layer, 16-285 
programming, 16-287 
serial infra-red mode register | 
(IRMODE), 16-287 
IrDA, about, 16-192 
mask register (SCCM), 16-181 - 
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memory map, 3-9 | 
parameter RAM memory map, 16-176 
protocol-pecific mode register (PSMR), 16-170 
protocols, 16-157 
status register (SCCS), 16-181 
switching protocols, 16-194 
timing, 16-183 
transmit-on-demand register (TODR), 16-171 
Transparent mode, 16-294 
commands, 16-300 
errors, 16-302. 
event register (SCCE- ianeperen!): 
16-307. 
examples, 16-310 
features, 16-295 
frame reception, 16-296 
frame transmission, 16-295 
mask register (SCCM-Transparent), 
16-309 
operation, 16-294 
. parameter RAM memory map, 16-300 
receive buffer descriptor, 16-303 
status register (SCCS-Transparent), 
16-309 
synchronization, 16-296 , 
transmit buffer descriptor, 16-305 
UART mode, 16-195 
break support, 16-205 
commands, 16-201 | 
control characters, 16-203 
errors, 16-208 
features, 16-196 | 
fractional stop bits, 16-207 | 
parameter RAM memory map, 16-198 
programming example, 16- 224, 16-226 
programming, 16-200 
receive buffer descriptor, 16-214 
recognizing addresses, 16-202 
SCC2 UART event register. 
(SCCE-UART), 16-221 
SCC2 UART mask register 
(SCCM-UART), 16-223 
SCC2 UART status register 
(SCCS-UART), 16-224 
sending a break, 16-206 
sending a preamble, 16-206 
transmit buffer descriptor, 16-218 
wake-up timer, 16-205 


serial DMA, 16-84 
serial interface, 16-113 


block diagram, 16-114 

change requirements, 16-123 

clock route registe (SICR), 16-134 
command register (SICMR), 16-136 
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global mode register (SIGMR), 16-126 
memory map, 3-11 

mode register (SIMODE), 16-127 
NMSI features, 16-115 


_ programming RAM entries, 16-120 


RAM modes, 16-123 

RAM operation, 16-118 

RAM pointer register (SIRP), 16-137 
status register (SISTR), 16-137 
testing modes, 16-116 

time-slot assigner features, 16-115 


serial management controllers, 16-372 


buffer descriptor operation, 16-374 
disabling on-the-fly, 16-380 
features, 16-373 
GCI mode, 16-415 
C/I channel handling, 16-416 
C/I channel reception, 16-416 
C/l channel transmission, 16-416 
commands, 16-420 
event register (SMCE-GCl), 16-422 
features, 16-415 
mask register (SMCM-GCl), 16-423 
mode register (SMCMR-GC)l), 16-421 
monitor channel reception, 16-416 
monitor channel transmission, 16-416 
operation, 16-416 
parameter RAM memory map, 16-417 
general parameter RAM memory map, 16-375 
general SMC mode register (SMCMR), 16-374 
memory map, 3-9 
parameter RAM memory map, 16-375 
Transparent mode, 16-399 
commands, 16-405 
errors, 16-406 
event register (SMCE-Transparent), 
16-412 
features, 16-399 
frame reception, 16-400 
frame transmission, 16-399 
interrupts, 16-415 
mask register (SMCM- Transparent), 
16-413 
_ mode register (SGMCMR-Transparent), 
16-406 | 
NMSI programming example, 16-413 
parameter RAM memory map, 16-405 
receive buffer descriptor, 16-408 
synchronization with SMSYNx, 16-401 
synchronization with the TSA, 16-403 
transmit buffer descriptor, 16-410 
TSA programming example, 16-414 
UART mode, 16-382 
commands, 16-386 
errors, 16-387 | 
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serial management controllers 
UART mode (continued) 
event register (SMCE-UART), 16-395 
features, 16-383 
frame reception, 16-384 
frame transmission, 16-383 
interrupts, 16-398 
mask register (SMCM-UART), 16-397 
mode register (SMCMR-UART), 16-388 
parameter RAM memory map, 16-384 
programming example, 16-397 
programming, 16-385 
receive buffer descriptors, 16-389 
sending a break, 16-386 
sending a preamble, 16-387 
transmit buffer descriptor, 16-393 
unsupported features, 16-382 
serial peripheral interface, 16-423 
buffer descriptor ring, 16-432 
command register (SPCOM), 16-441 
commands, 16-431 
event register (SPIE), 16-442 
interrupts, 16-445 
mask register (SPIM), 16-443 
master programming example, 16-443 
memory map, 3-10 
mode register (SPMODE), 16-433 
operation, 16-425 
multimaster, 16-427 
parameter RAM memory map, 16-428 
programming, 16-433 
receive buffer descriptor, 16-437 
slave programming example, 16-444 
transmission and reception, 16-426 
transmit buffer descriptor, 16-439 
serialization 
latency, 6-12 
SET TIMER command, 16-24 
SETUP token, 16-349 
SHIFT/CLK/CLK, 2-12 
show cycles (definition), 13-33 
SICMR, 16-136 
SICR, 16-134 
SIEL, 12-9 
SIGMR, 16-126 
signal timings, generating, 15-44 
signals, 2-2 
A, 17-3 
ALE_B, 2-7, 17-4 
AS, 2-6 
ATO, 2-8 
AT1, 2-7 
AT2, 2-7 
ATS, 2-8 
BB, 2-4 
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BDIP, 2-2 

BG, 2-4 

BI, 2-3 

BLANK, 2-11 
BPL_B1, 2-5 
BR, 2-4 
BRGO1, 2-8, 2-9 
BRGO2, 2-9 
BRGOS, 2-9 
BRGOUT2, 2-9 
BS_BO, 2-5 
BS_B1, 2-5 
BS_B2, 2-5 
BS_B3, 2-5 
BSY_B, 17-6 
BURST, 2-2 
bus interface, 13-4 
BVD2_B, 17-5 
CD2, 2-10 
CDx_B, 17-5 
CE1_B, 2-4 
CE2_B, 2-5 
CEx_B, 17-3 
CLK, 2-12 
CLK1, 2-8 
CLK2, 2-8 
CLKS, 2-9 
CLK4, 2-9 
CLKOUT, 2-6 
CS2, 2-6 


DPS, 2-4 

DREQ1, 2-10 

DREQ2, 2-10 

DSCK, 2-12 

DSCK/AT1, 2-7 

DSDI, 2-12 

DSDO, 2-8, 2-12 

EXTAL, 2-6 

EXTCLK, 2-6 

FIELD, 2-11 

FRAME, 2-11 

FRZ, 2-4 

general circuit interface, 16-145 
GND, 2-12 | 
GPL_AO, 2-5 

GPL_A1, 2-5 

GPL_A4, 2-6 
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GPL_A5, 2-6 
GPL_BO, 2-5 
GPL_B4, 2-6 
GPL_B5, 2-2 
HRESET, 2-6 
HSYNC, 2-11 
I2CSCL, 2-9 
l2CSDA, 2-9 
IDL bus, 16-142 
IDMA interface, 16-91 
internal clock, 5-16 
lOIS16, 17-4 
1O1IS16_B, 2-7 
IORD, 2-5 
IORD_B, 17-4 
IOWR, 2-5 
IOWR_B, 17-4 
IP_BO, 2-7 
IP_B1, 2-7 
IP_B2, 2-7 
IP_B3, 2-7 
IP_B4, 2-7 
IP_B5, 2-7, 2-8 
IP_B7, 2-8 
IREQ_B, 17-6 
IRQ, 17-6 
IRQO, 2-4 
IRQ1, 2-4 
IRQ2, 2-3 
IRQ3, 2-3 
IRQ4, 2-3 
IRQ5, 2-4 
IRQ6, 2-4 
IRQ7, 2-4 
IWPO, 2-7 
IWP1, 2-7 
IWP2, 2-7 
KAPWR, 2-12 
KR, 2-3 
L1RCLKA, 2-8 
L1RQA, 2-10 
LiIRSYNCA, 2-10 
L1RXDA, 2-8 
LiST1, 2-9 
LiST2, 2-10 
L1iST3, 2-10 
L1iST4, 2-10 
LiST5, 2-10 
LiST6, 2-10 
L1ST7, 2-10 
L1ST8, 2-10 
LiITCLKA, 2-9 
LITSYNCA, 2-10 
L1TXDA, 2-8 


LCD_A, 2-9 
LCD_AC, 2-11 
LCD_B, 2-9 
LCD_C, 2-10 
LDOo, 2-11 
LD1, 2-11 
LD2, 2-11 
LD3, 2-11 


LD4, 2-11 


LD8, 2-11 
LOAD, 2-11 
LOE, 2-11 
LWPO, 2-7 
LWP1, 2-7, 2-8 
MODCK1, 2-8 
MODCk2, 2-8 
N/C, 2-12 

OE, 2-5 

OE_B, 17-4 
OPS, 2-8 
PCMCIA, 17-3 
PCOE, 2-5 | 
PCWE, 2-5 
POE_B, 17-6 
PORESET, 2-6 
power supply, 2-12 
PTR, 2-8 ; 
R/W, 17-4 
RD/WR, 2-2 
RDY, 17-6 
REG, 2-2, 17-3 
RESET_B, 17-6 
RETRY, 2-3 
RSTCOMF, 2-6 
RSV, 2-3 
RTS2, 2-10 
RXD2, 2-8 
SDACK1, 2-9, 2-10 
SDACK2, 2-9 
SHIFT/CLK/CLK, 2-12 
SMRXD1, 2-9 
SMRXD2, 2-8 
SMSYN1, 2-9 
SMSYN2, 2-9 
SMTXD1, 2-9 
SMTXD2, 2-8 
SPICLK, 2-9 
SPIMISO, 2-9 
SPIMOSI, 2-9 
SPISEL, 2-9 
SPKR, 17-6 
SPKROUT, 2-3, 17-6 
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SRESET, 2-6 
STS, 2-8 
STSCHG, 17-5 
TA, 2-3 

TCK, 2-12, 21-2 
TDI, 2-12, 21-2 
TDO, 2-12, 21-2 
TEA, 2-3 
TEXP, 2-7 
TGATE1, 2-10 
TGATE2, 2-10 
TIN1, 2-8 

TIN2, 2-9 

TINS, 2-8 

TIN4, 2-9 

TMS, 2-12, 21-2 
TOUT, 2-8 
TOUT2, 2-9 
TRST, 2-12, 21-2 
TS, 2-2 

TSIZO, 2-2 
TSIZ1, 2-2 
TXD2, 2-8 
UPWAITA, 2-6 
UPWAITB, 2-6 
USBOE, 2-8 
USBRXD, 2-8 
USBRXN, 2-10 
USBRXP, 2-10 
USBTXN, 2-10 
USBTXP, 2-10 
VDO, 2-11 

VD1, 2-11 

VD2, 2-11 

VD3, 2-11 

VD4, 2-11 

VD5, 2-11 

VD6, 2-11 

VD7, 2-11 
VDDH, 2-12 
VDDL, 2-12 
VDDSYN, 2-12 
VFO, 2-7 

VF1, 2-7 

VF2, 2-7 
VFLSO, 2-7 
VFLS1, 2-7 
VSSSYN, 2-12 
VSSSYN1, 2-12 
VSx_B, 17-5 
VSYNGC, 2-11, 20-3 
WAIT_B, 2-7, 17-4 
WE_B, 17-4 
WEO, 2-5 
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WE1, 2-5 

WE2, 2-5 

WE8, 2-5 

WP, 17-5 

XFC, 2-6 

XTAL, 2-6 
silicon, Revision A note, i 
SIMASK, 12-8 
SIMODE, 16-127 
single beat transfers, 13-8 

read, 13-9 

write, 13-12 
SIPEND, 12-7 
SIRP, 16-137 
SISTR, 16-137 
SIU interrupt edge/level register, 12-9 
SIU interrupt mask register, 12-8 
SIU interrupt pending register, 12-7 
SIU interrupt vector register, 12-10 
SIU module configuration register, 12-30 
SIUMCR, 12-30 
SIVEC, 12-10 
slave, 16-425 
SMC (definition), 16-372 
SMCE-GCIl, 16-422 
SMCE-Transparent, 16-412 
SMCE-—UART, 16-395 
SMCM-GCI, 16-423 
SMCMR, 16-374 
SMCMR-GCI, 16-421 
SMCMR-Transparent, 16-406 
SMCMR-UART, 16-388 
SMCM-Transparent, 16-413 
SMCM-UART, 16-397 
SMRXD1, 2-9 
SMRXD2, 2-8 
SMSYN1, 2-9 
SMSYN2, 2-9 
SMTXD1, 2-9 
SMTXD2, 2-8 
soft reset configuration, 4-12 
soft reset, registers affected, 6-24 
software monitor debugger, 20-40 
software request, initiating, 15-44 
software service register, 12-27 
software tablewalk routine, minimizing, 11-9 
software watchdog timer, 12-26 

block diagram, 12-27 
SPCOM, 16-441 
specialized RAM memory map, 3-11 
specifications (electrical), 22-1 
SPI (definition), 16-423 
SPICLK, 2-9 
SPIE, 16-442 
SPIM, 16-443 
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SPIMISO, 2-9 
SPIMOSI, 2-9 
SPISEL, 2-9 
SPKROUT, 2-3 
SPLL, 5-1, 5-12 
SPMODE, 16-433 
SRAM interface, 15-39 
SRESET, 2-6, 4-3 
SRRO and SRA, 6-16, 7-9 
stability, SPLL, 5-13 
start addresses, 15-54 
START OF FRAME token, 16-350 
static branch prediction, 6-6 
status, of the master, 13-33 
storage reservation, 13-38 
store (instruction), 10-12 
store, 11-48 
strobes, 16-116 
STS, 2-8, 13-5, 13-33 
stwcx, 13-5, 13-38 
conditions, 13-40 
failure, 13-40 
switching endian modes, 14-5 
SWSR, 12-27 
SWT, 12-26 
sync, 10-13 
synchronization 
clock frequency, 5-20 
in SCC2 Transparent mode, 16-296 
patterns, 16-297 
signals, 16-298 
the trace window to internal core events, 20-6 
Transparent example, 16-299 
synchronous bus masters, 15-65, 15-68 
synchronous mode, 16-197 
SYPCR, 12-35 
system (definition), 14-1 
system clock and reset control register, 5-3 
system clock control key, 5-27 
system configuration (illustration), 12-4 
system design, 1-13 
system integration timers memory map, 3-3 
system interface unit, 12-1 
bus monitor, 12-11 
configuration, 12-2 
features, 12-2 
freeze operation, 12-28 
interrupts, 12-5 
programming, 12-7 
source priority, 12-6 
structure, 12-5 


PowerPC timebase, 12-14 
programming, 12-30 
real-time clock, 12-17 
software watchdog timer, 12-26 
system configuration and protection 
registers, 12-30 
system phase-locked loop, 5-1 
system protection control register, 12-35 
system protection, 15-5 
system reset interrupt, 6-24 
system reset, VCCOUT, 5-17 


T 


TA not asserting, 13-41 

TA, 2-3, 13-6, 13-36, 15-64 

tablewalk operation, 11-49 

tablewalk, 11-5 

TAP (definition), 21-1 

TB, 12-14 

TBK, 5-27 

TBREFFOK, 5-27 

TBREFF1K, 5-27 

TBREFL, 12-15 

TBREFU, 12-15 

TBSCR, 12-16 

TBSCRK, 5-27 

TCK, 2-12 

TCLK, 16-314 

TCNx, 16-82 

TCRx, 16-82 

TDI, 2-12 

TDM (definition), 16-113 

TDM channel routing, 16-118 

TDO, 2-12 

TEA assertion, not occurring, 15-16 

TEA, 2-3, 13-6, 13-36 

TECR, 20-31 

termination 
LocalTalk frame, 16-258 

termination control of a bus cycle error, 13-41 

termination signals, 13-37 

terminology, 24-1 

TERx, 16-83 

TESR, 12-36 

test access port, 21-1 
block diagram, 21-2 
boundary scan bit order, 21-6 
boundary scan register, 21-4 
instruction register, 21-19 


instructions 
memory map, 3-1 bypass, 21-20 
periodic interrupt timer, 12-22 i 94-20 
pin multiplexing, 12-29 eae DA0 
PowerPC decrementer, 12-12 hi-z, 21-20 
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test access port (continued) 
sample/preload, 21-20 
restrictions, 21-21 
TAP controller, 21-3 
TEXP, 2-7 
TGATE1, 2-10 
TGCRx, 16-79 
timebase and decrementer register key, 5-27 
timebase reference register 0 key, 5-27 
timebase reference register 1 key, 5-27 
timebase reference registers, 12-15 
timebase register mapping, 6-16 
timebase register, 12-14 
timebase status and control register key, 5-27 
timebase status and control register, 12-16 
timebase, 12-14 
time-fill, 16-266 
timer capture registers (TCRx), 16-82 
timer counter registers (TCNx), 16-82 
timer event registers (TERx), 16-83 
timer global configuration register (TGCRx), 16-79 
timer global configuration register, 16-78 
timer mode registers (TMRx), 16-80 
timer reference registers (TRRx), 16-81 
timers, 16-76 
key memory map, 3-4 
memory map, 3-7 
time-slot assigner 
configuration, 16-115 
connections, 16-118 
features, 16-115 
timing : 
bus arbitration (illustration), 13-30 
instruction cycles, 8-1 
SCC2, 16-183 
single buffer, 16-111 
TIN1, 2-8 
TIN2, 2-9 
TINS, 2-8 
TIN4, 2-9 
TLB manipulation 
loading the reserved TLB entries, 11-51 
TLB invalidation, 11-51 | 
TLB replacement counter, 11-51 
tlbia, 11-15 
tlbie, 11-15 
TMRx, 16-80 
TMS, 2-12 
tokens 
IN, 16-349 
PRE, 16-350 | 
SETUP, 16-349 
SOF, 16-350 
TOUT1, 2-8 
TOUT2, 2-9 
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tracking microcontroller loading, 16-27 
transfer error status register, 12-36 
transfer start, 13-31 
transfers on the bus 
alignment and packaging, 13-25 
basic, 13-8 
burst, 13-16 
read (bytes), 13-26 
single beat, 13-8 
write (patterns), 13-27 
transfers, burst-inhibited, 13-16 
translation table structure, 11-5 
transparency decoding, receiver, 16-264 
transparency encoding, transmitter, 16-264 
Transparent mode 
SCC2, 16-294 
TRRx, 16-81 
TRST, 2-12 
TS, 2-2, 13-5 
TSA (definition), 16-113 
TSIZO, 2-2 
TSIZ1, 2-2 
TXD2, 2-8 
types of watchpoints and breakpoints, 20-11 


U 


UART 
character format, 16-195 
definition, 16-195 
modes 
SCC2, 16-195 
SMC, 16-382 
universal serial bus, 16-342 
buffer descriptors 
receive, 16-358 
ring, 16-366 
transmit, 16-361 
command register (USCOM), 16-364 
commands, 16-355 
endpoint parameters, 16-352 
endpoint registers (USEPx), 16-365 
errors, 16-356 
event register (USBER), 16-368 
features, 16-343 
host controller 
limitations, 16-344 
initialization example, 16-369 
mask register (USBMR), 16-369 
memory map, 3-8 
mode register (USMOD), 16-357 
modes, 16-347 
operation, 16-342, 16-345 
parameter RAM memory map, 16-350 
programming, 16-357 
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universal serial bus (continued) 
slave address register (USADR), 16-363 
status register (USBS), 16-369 
tokens, 16-348 
transmission and reception, 16-347 
UPM, holding in a particular state, 15-65 
UPM (definition), 15-41 
UPM cycle, initiating, 15-41 
UPM locations addressed, 15-42 
UPM routine execution, 15-17 
UPWAITA, 2-6 
UPWAITB, 2-6 
USADR, 16-363 | 
USB (definition), 16-342 
USB and SCC2 priority, 16-490 
USBER, 16-368 
USBMR, 16-369 
USBOE, 2-8 
USBRXD, 2-8 
USBRXN, 2-10 
USBRXP, 2-10 
USBS, 16-369 
USBTXN, 2-10 
USBTXP, 2-10 
USCOM, 16-364 
USEP, 16-365 
user-programmable machines 
block diagram, 15-41 
programming, 15-44 
RAM array, 15-48 
RAM word, 15-49 
requests 
exception, 15-44 
memory access, 15-43 
memory periodic timer, 15-43 
software, 15-43 
wait mechanism, 15-65 
using a low frequency crystal circuitry, 5-10 
USMOD, 16-357 


V 


VBCB, 19-9 
VCCR, 19-5 
VCMR, 19-8 
VDO, 2-11 
VD1, 2-11 
VD2, 2-11 
VD83, 2-11 
VD4, 2-11 
VD5, 2-11 
VD6, 2-11 
VD7, 2-11 
VDDH, 2-12 
VDDL, 2-12 


VDDSYN, 2-12, 5-23 
vertical sync, 18-4 
VF instruction type encoding, 20-4 
VFO, 2-7 
VF1, 2-7 
VF2, 2-7 
VFAAO, 19-11 
VFAA1, 19-14 
VFBAO, 19-12 
VFBA1, 19-15 
VFCRO, 19-10 
VFCR1, 19-13 
VFLSO, 2-7 
VFLS1, 2-7 
video background color buffer register, 19-9 
video command register, 19-8 
video controller 
block diagram, 19-3 
clock, 19-3 
features, 19-2 
FIFO and DMA control, 19-4 
image sizes, 19-4 
memory map, 3-4 
operation, 19-2 
programming examples 
NTSC, 19-20 
PAL, 19-24 
RAM array 
format, 19-17 
registers, 19-5 
background color buffer register 
(VBCB), 19-9 
command register (VCMR), 19-8 
configuration register (VCCR), 19-5 
frame buffer A start address register set 0 
(VFAAO), 19-11 
frame buffer A start address set 1 
(VFAA1), 19-14 
frame buffer B start address register set 0 
(VFBAO), 19-12 
frame buffer B start address register set 1 
(VFBA1), 19-15 
frame configuration register set 0 
(VFCRO), 19-10 
frame configuration set 1 (VFCR1), 19-13 
status register (VSR), 19-7 
switching image sizes, 19-4 
video controller configuration register, 19-5 
video frame buffer A start address register 
set 0, 19-11 
video frame buffer A start address register 
set 1, 19-14 
video frame buffer B start address register 
set 0, 19-12 
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video frame buffer B start address register 
set 1, 19-15 
video frame configuration register set 0, 19-10 
video frame configuration register set 1, 19-13 
video status register, 19-7 
video system (illustration), 19-1 
voltage failure, 4-2 
VSR, 19-7 
VSSSYN, 2-12, 5-23 
VSSSYN1, 2-12, 5-23 
VSYNC, 2-11 


W 


WADD, 16-72 
applications, 16-75 
coefficients and sample data buffers, 16-73 
function descriptor, 16-73 
parameter packet, 16-74 
wait mechanism, 15-65 
wait state configuration, 15-35 
wait state, exiting, 15-66 
WAIT_B, 2-7 
wake-up timer, 16-205 
watchpoints, 6-5, 20-9 
WBS (definition), 15-42 
WEO, 2-5 
WE1, 2-5 
WE2, 2-5 
WES, 2-5 
window trace, 20-6 
write protection, 15-38 
write-protect error, 15-15 
write-protect violations, 15-7 
write-protecting registers, 5-27 
writethrough mode, 10-12, 11-4 
WSS (definition), 15-42 — 


X 


XER, 6-16, 6-23 

XFC, 2-6, 5-23 

XOFF, 16-203, 16-226 
XON, 16-203, 16-226 
XTAL, 2-6 
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